#### 1.0 INTRODUCTION

Western Digital's WD42C22C integrates a high performance, low cost Winchester formatter/controller, host interface, a buffer manager, and CRC/ECC generator/checker in a single 84-pin LSI device. Operating from a single +5V power supply, the WD42C22C is implemented in a low power CMOS design and is available in an 84-pin PLCC or PQFP (Figure 1). Figure 2 is a block diagram of the WD42C22C.

#### 1.1 FEATURES

· Enhanced host interface

IBM Personal Computer AT and XT port compatible

Supports AT speeds up to 16 MHz, 1 wait state I/O and 0 wait state memory using 120 ns static RAM (SRAM)

Supports AT speeds up to 16 MHz, 1 wait state I/O and 0 wait state memory using 100 ns SRAM

Selectable DMA or programmed I/O data transfers in all host interface modes

Host port slave mode compatible with ALE based peripherals such as the WD33C93 SBIC

Host transfer rates up to 4 Mwords/s for AT, 4 MB/s for XT. 10 MB/s for SCSI

Internal 12 mA high current drivers for direct connection to the XT or AT system bus

· Advanced buffer manager

Supports 1:1 interleave without resorting to wait states

Direct interface for up to 32 KB of static RAM

Sustained RAM bandwidth up to 10 MB/s Pipelined host and disk address counters

Operates as either ring or scatter-gather buffer

Allows full track buffering and facilitates look ahead cacheing algorithms

Adaptable disk controller

Software selectable MFM, RLL 2,7, or NRZ disk interface

Software selectable 56 bit ECC, 32 bit ECC, or 16 bit CRC

Software selectable 5, 11, or 22 bit error correction span



FIGURE 1, 84-PIN PLCC OR PQFP

Software selectable default sector lengths of 128, 256, 512, and 1024 bytes

User programmable sector size up to 2048 bytes

Software selectable 3 bit or 4 bit head number field

Reads and writes at 1:1 Interleave regardless of the formatted interleave

15 Mbs data transfer rate for MFM and RLL

24 Mbs data transfer rate for NRZ

Supports hard or soft sectored formats

Supports "zero latency" read operations Internal defect management of sector and track level alternates

Able to read ESDI defect list format

Supports sector servo schemes by disabling WRITE GATE over servo when formatting Internal 48 mA drivers and Schmitt trigger input receivers for direct connection to the

drive control cableIntegrated support features

Programmable master/slave mode allows two Integrated Drive Electronics (IDE) disks on one connector

Supports both Intel-type(80xx) and Motorola-type(68xx) microcontrollers

//

12/4/90

Internal power-qualified reset to detect low  $V_{\rm DD}$ 

- Low power sleep mode
- Available in 84-pin PLCC or 84-pin PQFP

#### 1.2 DESCRIPTION

#### 1.2.1 Enhanced Host Interface

The WD42C22C host interface port directly connects to the host system bus via internal 12 mA drivers. When operating in either AT or XT mode, all host control, data, and task file address lines directly connect to the WD42C22C. Mapping the device to the desired host system I/O addresses

requires external address decode logic. Integrated I/O port compatible AT and XT task file registers assure system compatibility.

To satisfy requirements for faster system bus rates and data transfers, the WD42C22C can operate in 12 MHz or 16 MHz, 1 wait state I/O channels (0 wait state memory) of 286 or 386 microprocessors. DMA or PIO data operations transfer at a rate of 4 Mwords/s (AT mode) or 4 MB/sec (XT mode). In addition to traditional single mode DMA, burst mode DMA transfers are also available.

An alternative host mode, slave mode, allows communication between the microcontroller and a peripheral device through the host interface. The slave device transfers data to the buffer RAM by



FIGURE 2. WD42C22C BLOCK DIAGRAM

27

using a slave DMA scheme such as the WD-BUS mode in the WD33C93 SCSI bus interface controller (SBIC).

#### 1.2.2 Advanced Buffer Management

The WD42C22C contains an advanced buffer manager satisfying the interface requirements between a byte or word wide host interface bus and a high speed serial disk interface. Optimized for the block oriented data structures of a disk controller, the WD42C22C can manage multiple sector buffers up to 32 KB. Each sector buffer can be any size to 2055 bytes. Pipelined host and disk address counters enable sustained, simultaneous transfers on each port. Sufficient RAM buffer bandwidth is available to support 1:1 interleaved 20 Mb/s disk transfers while simultaneously performing 16-bit host transfers at a rate in excess of 3 Mwords/s. Achieving maximum RAM bandwidth requires using 70 ns static RAM.

The pipelined structure of the buffer manager controls the buffer RAM in either a simple ring structure or a more advanced scatter-gather structure.

#### 1.2.3 Adaptable Disk Controller

The WD42C22C's versatile design makes the device adaptable for a wide variety of disk interface operations. A designer can select from three data formats, MFM, RLL 2,7, or NRZ. Disk data rates range up to 15 Mbits/s with MFM and RLL 2,7 encoding, while NRZ data rates range up to 24 Mbits/s. To support varied data format requirements, the WD42C22C operates in hard or soft sectored mode with programmable sector sizes to 2048 bytes and programmable ID PLO, data PLO, and GAP lengths.

Software selectable retry algorithms and 32 or 56-bit ECC polynomials enhance data integrity. Data integrity can further be ensured through the use of the device's built-in advanced defect management. The WD42C22C can be programmed to automatically detect the presence of a previously assigned defective sector and identify the location of the alternate sector. This allows access to alternate sectors without the typical additional rotational latency associated with defect handling.

With the pipelined architecture of the buffer manager, the designer can program the disk controller to execute "zero-latency" multiple sector read operations. In this mode of operation, the WD42C22C immediately commences data transfer to the RAM buffer upon encountering the first sector on the desired track. All subsequent sectors transfer to the buffer within a single rotational period. Host transfers begin upon location of the first requested sector within the buffer. Simultaneous host and disk transfers continue until all sectors are read from the drive. Zero-latency operation makes available an entire track of data to the host within one rotational period from the time the host requested the data. This differs from traditional implementations which read the entire track within one rotational period after the first requested sector has been located. Zero latency read operations eliminate the typical one-half rotational period average latency required to locate the first sector in full track data transfers

The WD42C22C includes an internal power qualified reset circuit for power up and power down conditions. This circuit eliminates the need for costly external circuitry that traditionally performed this function.

The WD42C22C features a multiplexed address/data bus on the microcontroller interface port and supports both Intel (80XX) and Motorola (68XX) type microcontrollers. An internal circuit automatically determines the connected microcontroller and configures the ports for direct interfacing.

Internal 48 mA drivers and Schmitt triggers input receivers provide direct connection to the drive control cable. Programmable input polarities assist in integrated drive electronics (IDE) designs.

#### 1.2.4 Flexibility of Application

As a result of its level of integration, a designer can create a wide variety of products. In addition to traditional stand alone Winchester controller boards, the WD42C22C is ideal for multi-function boards, direct system motherboards, and IDE applications. Special design considerations within the WD42C22C facilitate these applications.

#### 1.2.5 Typical Application

With an external microcontroller, buffer RAM, and a data separator such as the WD10C22B, the

**//** 

WD42C22C forms the basis of a Winchester disk controller product. For AT and XT applications, direct interfacing is available to the system bus. In these applications, the WD42C22C requires external address decoding to select the primary and secondary I/O address range of the WD42C22C. Other bus interfaces are supported via auxiliary bus controllers such as the WD33C93A SCSI Bus Interface Controller.

For ST506 (MFM) and ST412HP (RLL) applications, the WD42C22C directly connects to the WD10C22 data separator. (Like the WD42C22C, the WD10C22B supports both MFM and RLL encoding methods.) An external microcontroller implements interface specific control lines, e.g. the

ST506's STEP and DIRECTION signals. For ESDI applications, the WD42C22C operates in NRZ mode.

#### 1.2.6 Pin Descriptions

This section lists the pin number, signal name, and function for all the WD42C22C's pins. The pin descriptions are arranged by functions. Table 1 describes the pin designations for the host interface. Table 2 describes the pin designations for the local microcontroller interface. Table 3 describes the pin designations for the buffer interface. Table 4 describes the pin designations for the drive interface.

| PIN<br>NUMBER    | MNEMONIC                          | SIGNAL NAME                                                                       | I/O           | FUNCTION                                                                                                                                                                                                                                                                                                                                        |
|------------------|-----------------------------------|-----------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>2<br>3<br>4 | HA0<br>HA1<br>HA2<br>HA9/<br>HALE | HOST ADDRESS 0<br>HOST ADDRESS 1<br>HOST ADDRESS 2<br>HOST ADDRESS 9/<br>HOST ALE | <br> -<br> /O | Schmitt-triggered input. These four inputs are used to address the internal registers. Internal decoding of these address signals is a function of the AT/XT and HSMB mode bits. Port compatibility is maintained for both the AT and XT. In slave host mode HALE is used by the peripheral device to latch the address from HD0 through HD7.   |
| 5                | HRE                               | HOST READ<br>ENABLE                                                               | I/O           | Schmitt-triggered input. HRE is asserted by the AT or XT with HCS to read an internal register or the FIFO. In slave mode, HRE is asserted when MRE is asserted. It can also be asserted by the slave peripheral in DMA mode.                                                                                                                   |
| 6                | HWE                               | HOST WRITE<br>ENABLE                                                              | I/O           | Schmitt-triggered input. HWE is asserted by the AT or XT with HCS to write an internal register or the FIFO. In slave mode, HRE is asserted when MRE is asserted. It is also asserted by the slave peripheral in DMA mode.                                                                                                                      |
| 7                | HCS                               | HOST CHIP<br>SELECT                                                               | I/O           | Schmitt-triggered input. HCS should be decoded from the AT or XT address bus and is used to qualify HRE and HWE for host accesses. In slave mode, HCS is asserted when the local microcontroller is accessing the slave device address space.                                                                                                   |
| 8                | IOCS16/<br>DREQ                   | I/O CHIP SELECT<br>16/<br>DMA REQUEST                                             | 0             | This output is <u>program</u> mable to function as the AT bus signal IOCS16 when the PIO mode is selected or as a DMA Request signal (DREQ) in the DMA mode. This output is tristated at power-up and remains tristated until the interface mode is set by the local microcontroller. IOCS16 is an open-drain ouput. DREQ is a tristate output. |
| 9                | DACK/<br>RCS                      | DMA ACKNOW-<br>LEDGE/<br>RAM CHIP SELECT                                          | I             | Schmitt-triggered input. DACK is asserted by the host in response to the DREQ signal assertion in order to complete the DMA handshake. RCS is used in slave mode to qualify host data transfers to/from the FIFO.                                                                                                                               |

**TABLE 1. HOST INTERFACE PIN DESCRIPTION** 

**//** 

12/4/90 27-5

| PIN<br>NUMBER                                        | MNEMONIC            | SIGNAL NAME                      | I/O | FUNCTION                                                                                                                                                                                                                           |
|------------------------------------------------------|---------------------|----------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23                                                   | RESET               | RESET                            | I/O | Open-drain output and Schmitt input, can be wire-ORed with an external reset. The WD42C22C resets all logic except the Task File when this input is asserted. On power-up, or when requested by the host, this output is asserted. |
| 75<br>thru<br>82,<br>40,<br>41,<br>42,<br>44<br>thru | HD0<br>thru<br>HD15 | HOST DATA 0 thru<br>HOST DATA 15 | I/O | Schmitt-triggered inputs. These 16 pins are used during host 16-bit data transfers, and the lower eight bits (HD0-HD7) are used for bytewide host data transfers as well as all command and status information transfers.          |
| 74                                                   | INTRQ               | INTERRUPT<br>REQUEST             | I/O | INTRQ indicates to the AT or XT that a data blocktransfer is requested or a command has been completed. In slave host mode INTRQ is asserted by the slave peripheral device.                                                       |
| 83                                                   | $V_{SS}$            | GROUND                           |     | Ground.                                                                                                                                                                                                                            |
| 84                                                   | $V_{DD}$            | +5V                              |     | +5V                                                                                                                                                                                                                                |

TABLE 1. HOST INTERFACE PIN DESCRIPTION (CONT'D)

| PIN<br>NUMBER    | MNEMONIC           | SIGNAL NAME                                   | I/O | FUNCTION                                                                                                                                                                                                               |
|------------------|--------------------|-----------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22               | $V_{SS}$           | GROUND                                        |     | Ground.                                                                                                                                                                                                                |
| 24               | MCINT              | µCONTROLER<br>INTERRUPT                       | 0   | This output is used as an interrupt signal in order to alert the local microcontroller it is necessary to check command parameters or status. For the XT mode, MCINT is asserted when the controller is selected.      |
| 25               | ALE/AS             | ADDRESS LATCH<br>ENABLE/<br>ADDRESS STROBE    | I   | Schmitt-triggered input. ALE is used to latch<br>the lower eight address bits from the multi-<br>plexed address/data lines (AD7-AD0). AS is<br>used for this function when tied to a Motorola<br>type microcontroller. |
| 26               | MRE/DS             | µCONTROLLER<br>READ ENABLE<br>/DATA STROBE    | I   | Schmitt-triggered input. MRE is asserted by the local microcontroller to read an internal register or the buffer. DS is used in Motorola type microcontrollers to enable the data transfer.                            |
| 27               | MWE/<br>MR/W       | uCONTROLLER<br>WRITE ENABLE/<br>uC READ/WRITE | ı   | Schmitt-triggered input. MWE is asserted by the local microcontroller to write an internal register or the buffer. MR/W is used by Motorola type microcontrollers to set the direction of data transfers.              |
| 28<br>thru<br>35 | AD0<br>thru<br>AD7 | ADDRESS/DATA 0<br>thru<br>ADDRESS/DATA 7      | I/O | Schmitt-triggered inputs. These multiplexed address/data lines are used to load the register/buffer address on the falling edge of ALE, and are used for data transfers to/from the local microcontroller.             |
| 43               | Vss                | GROUND                                        |     | Ground.                                                                                                                                                                                                                |

TABLE 2. LOCAL MICROCONTROLLER INTERFACE PIN DESCRIPTION

| PIN<br>NUMBER    | MNEMONIC            | SIGNAL NAME                             | 1/0 | FUNCTION                                                                                                                                                                                                 |
|------------------|---------------------|-----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38               | XTALIN              | CRYSTAL<br>INPUT                        | 1   | Crystal oscillator input. The crystal frequency is twice the buffer data rate.                                                                                                                           |
| 39               | XTALOUT             | CRYSTAL<br>OUTPUT                       | 0   | Crystal oscillator output.                                                                                                                                                                               |
| 49               | BOE                 | BUFFER OUTPUT<br>ENABLE                 | 0   | BOE is asserted by the chip to read data from the external SRAM buffer.                                                                                                                                  |
| 50               | BWE                 | BUFFER WRITE<br>ENABLE                  | 0   | BWE is asserted by the chip to write data into the external SRAM buffer.                                                                                                                                 |
| 51<br>thru<br>58 | BD0<br>thru<br>BD7  | BUFFER DATA 0<br>thru<br>BUFFER DATA 7  | I/O | Schmitt-triggered. Buffer data bus, which connects directly to a static RAM.                                                                                                                             |
| 59<br>thru<br>73 | BA0<br>thru<br>BA14 | BUFFER ADDR 0<br>thru<br>BUFFER ADDR 14 | I/O | Buffer address bus, for direct connection to 32 KB of SRAM. In XT mode, also used to read jumper configuration data in Read Configuration Mode. In input mode, there is a low current internal pulldown. |

**TABLE 3. BUFFER INTERFACE PIN DESCRIPTION** 

| PIN<br>NUMBER | MNEMONIC       | SIGNAL NAME                           | I/O | FUNCTION                                                                                                                                                                                                                                                                          |
|---------------|----------------|---------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10            | WD             | WRITE DATA                            | 0   | WD is the MFM/NRZ write data written to the disk. It is shifted out at a rate determined by write clock. MFM write data should be synchronized by a D flip flop clocked at 10 MHz (for 5 Mbs operation).                                                                          |
| 11            | LATE/<br>WCOUT | LATE/<br>WCOUT                        | 0   | LATE is used along with EARLY in the Write Precompensation circuitry to control the delay of WD.                                                                                                                                                                                  |
|               |                |                                       |     | In NRZ mode WCOUT is write clock out which can be used to qualify WD in an ESDI application.                                                                                                                                                                                      |
| 12            | AME/<br>EARLY  | ADDRES <u>S MAR</u> K<br>ENABLE/EARLY | 0   | In NRZ mode, this output is the Address Mark Enable signal for an ESDI drive. In MFM or RLL mode, this output is EARLY. EARLY and LATE are used in the Write Precompensation circuitry to control the delay of WD.                                                                |
| 13            | WG             | WRITE GATE                            | 0   | WG is asserted when valid data is to be written to the disk. It enables write current to the head and is immediately de-asserted if a WRITE FAULT (WF) is detected.                                                                                                               |
| 14            | WC             | WRITE CLOCK                           | ı   | A clock used internally to control WD. (Up to 10 MHz for ST412, up to 15 MHz for ESDI).                                                                                                                                                                                           |
| 15            | INDEX          | INDEX                                 | I   | Schmitt-triggered INDEX input for direct connection to the drive control cable.                                                                                                                                                                                                   |
| 16            | SCT/<br>DRUN   | SECTOR/<br>DATA RUN                   | I   | Schmitt-triggered input. In hard sector mode, SCT is used to indicate the start of a sector. In soft sector NRZ mode, SCT indicates Address Mark Found. In soft sector MFM or RLL mode, DRUN indicates a sequence of MFM or RLL '0's or a sequence of MFM '1's has been detected. |
| 17            | RD             | READ DATA                             | I   | RD is MFM or NRZ read data from the drive. Data and clocks are separated internally for MFM data.                                                                                                                                                                                 |
| 18            | RG             | READ GATE                             | 0   | RG is asserted to initiate a search for an address mark. It remains asserted until the end of the ID or data field.                                                                                                                                                               |

**TABLE 4. DRIVE INTERFACE PIN DESCRIPTION** 

1/2

| PIN<br>NUMBER | MNEMONIC   | SIGNAL NAME                      | I/O | FUNCTION                                                                                       |
|---------------|------------|----------------------------------|-----|------------------------------------------------------------------------------------------------|
| 19            | RC         | READ CLOCK                       | ı   | RC is typically generated from an oscillator phase-locked to the read data.                    |
| 20            | WF         | WRITE FAULT                      | ı   | Schmitt-triggered. WRITE FAULT input for direct connection to the drive control cable.         |
| 21            | DRDY       | DRIVE READY                      | 1   | Schmitt-triggered. DRIVE READY input for direct connection to the drive control cable.         |
| 36<br>37      | DS0<br>DS1 | DRIVE SELECT 0<br>DRIVE SELECT 1 | 0   | High-current open-drain DRIVE SELECT outputs for direct connection to the drive control cable. |

TABLE 4. DRIVE INTERFACE PIN DESCRIPTION (CONT'D)

#### 2.0 ARCHITECTURE

#### 2.1 POWER-QUALIFIED RESET

This integrated function is used to reliably initialize flip-flops to a predictable state during the application of  $V_{DD}$ . It causes the RESET output signal to be asserted until  $V_{DD}$  reaches a given threshold. It also forces a reset if the  $V_{DD}$  falls below a specified threshold.

#### 2.2 DRIVE INTERFACE LOGIC

The drive interface contains high-current 48 mA drivers for direct connection of the drive select outputs to the drive control cable. Schmitt trigger input receivers connect the drive interface logic directly to the control cable inputs.

#### 2.3 DRIVE CONTROLLER ORGANIZATION

The controller is composed of the following major sections:

- PLA Control
- CRC/ECC Logic
- MFM/RLL Decoding
- Address Mark Detector
- · Buffer and DMA Control
- Task Register File

The controller is designed to operate with 2 clock inputs, READ CLOCK (RC) and WRITE CLOCK (WC). The PLA controller, processor interface, and buffer control sections use the write clock input. The clock inputs are used for MFM, RLL, or NRZ decoding. The clock frequency is 10 MHz for a 10 Mbs data rate.

The controller reads or writes disk data to a 15 Mbs rate for MFM and RLL and 24 Mbs for NRZ. The RLL implementation is a (2,7,2,4,3) code based on the IBM 3370 code. The only difference lies in the assignments of the code words to the 7 different data streams possible. Error propagation for a single bit error is limited to 4 bits.

When programmed in the NRZ mode, the WD42C22C qualifies NRZ disk data using the Sector / Address Mark Detect signal, and also modifies the RG and WG signals to meet ESDI specifications.

In all modes, the length of the PLO sync and gap fields are software programmable. The ID PLO sync field length, the Gap1/Gap3 length, the Gap1/Gap3 data bytes and the ID CRC pad bytes are programmable during the format command. The data PLO sync field length and the data CRC/ECC pad bytes are programmable during the Write command.

Figure 3 is a block diagram of the drive controller section of the WD42C22C.



FIGURE 3. DRIVE CONTROLLER BLOCK DIAGRAM

### 2.4 PROGRAMMABLE LOGIC ARRAY (PLA) CONTROLLER

The Programmabla Logic Array (PLA) controller interprets commands, e.g. write, read format, etc. This circuitry's operation is synchronized with the WC input. The PLA controller is started when a command is written into the command register. It generates control signals and operates in a handshake mode when communicating with the MFM/RLL decoding block. The MFM/RLL decoding block uses the RC input which may be asynchronous to WC.

#### 2.5 MAGNITUDE COMPARATOR

An 11-bit magnitude comparator calculated drive step direction and number of step pulses between present cylinder position and desired position in earlier Winchester controller versions. This comparator is **not** used in the WD42C22C. A separate high speed equivalence comparator is used to compare ID field bytes when searching for a sector ID field.

**//**/

#### 2.6 CRC/ECC GENERATOR AND CHECKER

The CRC/ECC generator computes and checks the cyclic redundancy check characters appended to the ID and data fields written on the disk. The CRC mode of operation, defined by the SDH register (bit 7 set to 0) provides a means of verifying the accuracy of the data read from the disk but does not attempt to correct it. (Bit 7 of the SDH register will not implement CRC mode for data fields when RLL mode is selected.) The CRC polynomial used is:

$$X^{16} + X^{12} + X^{5} + 1$$

The CRC register is preset to all ones before computation starts.

If the CRC character being generated while reading the data does not equal the one previously written, an error exists. If there is a CRC failure in the ID field, an ID not found is indicated by setting bit 4 of the error register. If the failure is in the data field, bit 6 of the error register is set.

A 32 bit or 56 bit ECC polynomial may be selected instead of the CRC polynomial for the data field. The CRC/ECC selection is controller by bit 7 of the SDH register when the controller is in MFM or NRZ modes. CRC is selected when bit 7 of the SDH register is 0 in MFM or NRZ modes. ECC is selected when bit 7 of the SDH register is 1 in MFM or NRZ modes. Bit 2 in the set parameter command selects either the 32 bit or 56 bit polynomial. RLL mode defaults to the 56 bit polynomial. The CRC or 32 bit ECC options are **not** usable in RLL mode.

The ECC mode of operation (SDH bit 7 = 1) is only applicable to the data field. This feature built into the WD42C22C provides the user with the ability to detect and correct errors in the data field automatically.

The following is a summary of the parameters considered when ECC is used:

- · SDH register bit 7.
- Read and write command bit 1 (L).
- · Compute correction command.
- · Set parameter command.
- Error occurred, bit 0 of the status register.
- On any ECC error the controller stops regardless of the T bit. (Refer to the read command description.)

The SDH register bit 7 must be equal to one to change from the CRC mode to the ECC mode, for MFM and NRZ only.

When an ECC error is detected, no attempt is made to correct it and bit 0 of the status register and bit 6 of the error register are set. The user now has two choices:

- Ignore the error and make no attempt to correct it.
- Use the compute correction command to determine the pattern and location of the error, and correct it within the user's program.

When implementing the compute correction command, use it before executing commands that alter the content of the ECC register. The read, write, scan, and format commands can alter the syndrome and make correction impossible. If the compution correction command determines that the error is uncorrectable, then the error bits in the status register and error register are set.

Although ECC generation starts with the first bit of the F8 byte in the data ID field, the actual ECC bytes produced for the sector are the same as if the A1 byte was included.

The 32-bit ECC polynomial is:

$$X^{32} + X^{28} + X^{26} + X^{19} + X^{17} + X^{10} + X^{6} + X^{2} + 1$$

and is the same one used in the WD1002, WD1003, and WD1006 controller boards. The 32-bit ECC polynomial has an 11 bit maximum single burst correction span. The reverse 32-bit ECC polynomial is:

$$X^{32} + X^{30} + X^{26} + X^{22} + X^{15} + X^{13} + X^{6} + X^{4} + 1$$

The non-detection probability for the 32-bit ECC polynomial is:

2.3 (E-10), 
$$r^{\dagger} = 516 \times 8$$
,  $b^{\dagger} = 5$  and the miscorrection probability is:  
1.57 (E-5),  $r^{\dagger} = 516 \times 8$ ,  $b^{\dagger} = 5$ 

The 56-bit ECC polynomial is:

$$X_{24}^{56} + X_{8}^{52} + X_{1}^{50} + X_{1}^{43} + X_{1}^{41} + X_{1}^{34} + X_{1}^{30} + X_{1}^{26} + X_{1}^{26} + X_{1}^{30} + X_$$

The 56-bit ECC polynomial has a 22 bit maximum single burst correction span.

The reverse 56-bit ECC polynomial is:

$$X_{-}^{56} + X_{-}^{48} + X_{-}^{32} + X_{-}^{30} + X_{-}^{26} + X_{-}^{22} + X_{-}^{15} + X_{-}^{13} + X_{$$

The non-detection probability for the 56-bit ECC polynomial is:

1.39 (E-17), 
$$r^{\dagger}$$
 = 519 x 8,  $b^{\dagger}$  =11

and the miscorrection probability is:

5.84 (E-11), 
$$r^{\dagger} = 519 \times 8$$
,  $b^{\dagger} = 11$ 

The set parameter command selects the number of bits in the correction span, through the use of bit 0.

Read and write commands, with the L bit (bit 1) set to one, are referred to as read long and write long commands. With these commands, no ECC or CRC characters are generated or checked by the WD42C22C. In effect, the four or seven bytes are handled as an additional four or seven bytes of data which pass through the data buffer. With proper use of the write, read long, write long, and read commands, a diagnostic routine may be developed to test the accuracy of the error correction process.

For CRC/ECC calculations, the CRC/ECC register is initialized to all 1's. For CRC/ECC purposes only, the address mark byte has a value of "A1" and is included in the CRC/ECC calculations.

### 2.7 MFM/RLL ENCODING AND MFM/RLL DECODING

The MFM/RLL encoding section receives 8-bit parallel data and generates either MFM or RLL write data depending on the K option in the load parameter block command. This section operates with a write clock having a frequency of the desired bit rate. The write clock need not be synchronized to read clock (RC).

Data bytes are written to the drive most significant bit first. The MFM/RLL decoding section generates 8 bit binary data from MFM or RLL read data once an address mark has been detected. Table 5 lists the RLL coding rules followed by the controller.

| NF    | RZ Da | ata  |     | RLL Code Word Output |                        |  |  |  |
|-------|-------|------|-----|----------------------|------------------------|--|--|--|
| First | Bit L | _ast | Bit | First Bit            | Last Bit               |  |  |  |
| 1     | 1     | X    | Χ   | 1000                 | XXXX                   |  |  |  |
| 1     | 0     | Х    | Χ   | 0100                 | $\times \times \times$ |  |  |  |
| 0     | 1     | 1    | Χ   | 0010                 | 0 0 X X                |  |  |  |
| 0     | 1     | 0    | Χ   | 0001                 | 0 0 X X                |  |  |  |
| 0     | 0     | 0    | Χ   | 1001                 | 0 0 X X                |  |  |  |
| 0     | 0     | 1    | 1   | 0000                 | 1 0 0 0                |  |  |  |
| 0     | 0     | 1    | 0   | 0010                 | 0 100                  |  |  |  |

**TABLE 5. RLL CODING RULES** 

When NRZ mode is selected, the MFM/RLL encode and decode logic is bypassed. NRZ read data is clocked in on the rising edge of Read Clock and NRZ write data is clocked out on the rising edge of WC.

#### 2.8 ADDRESS MARK DETECTOR

An address mark is a unique 2 byte code placed at the beginning of each ID field or data field. A series of zero bytes always precedes each address mark. The address mark detector section begins searching for an address mark when synchronization has been lost after a series of zero bytes is detected. The detection of an address mark establishes resynchronization.

The address mark is composed of a 2 byte sequence. The first byte is used for resynchronization and the second byte specifies ID or data field. For the MFM mode, the first byte is an A1<sub>16</sub> byte with missing clock (data = A1, clock = 0A). The second byte is encoded with normal MFM rules. FF through FC and F7 through F4 specify the beginning of an ID field and F8 specifies the beginning of a data field.

In RLL mode, the first byte is a unique code which violates normal RLL coding rules but does not violate the 2,7 timing rule. The RLL address mark pattern is 1000 0000 1001 0000 (8090<sub>16</sub>). The second byte is encoded with normal RLL rules. FF through FC and F7 through F4 specify the beginning of an ID field and F8 specifies the beginning of a data field.

**//**//

In NRZ mode, an NRZ A1 byte establishes byte synchronization. When the WD42C22C is used to control an ESDI (NRZ) drive, the Sector Pulse (Address Mark Found) signal will qualify read data to prevent false address mark detection.

### 2.9 CONTROLLER TO DATA SEPARATOR INTERFACE

The read interface section generates READ GATE (RG) from signals sent by the PLA controller and by the DRUN input. In this system, raw read data from the drive is presented to the RD in put. RG is low when the controller is not inspecting read data. When a read command is started and a search begins for an address mark, DRUN from the data separator is examined. Since each address mark should be preceded by approximately 12 bytes of zeroes, RG is activated when a sequence of zeroes is detected by DRUN and read data is examined until either an address mark is detected or a non-zero byte which is not an address mark is detected. If an address mark was detected, and it was preceded by at least 8 bytes of zeroes, read gate is held high and the ID or data field can be read

If a non-zero non-address mark byte was detected, then RG is dropped for at least 2 byte times, allowing the phase lock loop to resynchronize with WC, before inspecting DRUN input again. If the desired ID field was read, then the sector transfer can be made. If a data field was detected or if the ID bytes did not match, or if an address mark was not preceded by eight bytes of zeroes with six coming after RG on, then RG is lowered and DRUN is inspected again for a sequence of zeroes.

Figures 4 illustrates the PLL control sequence for the ID field. Figure 5 illustrates the PLL control sequence for the data field.



FIGURE 4. PLL CONTROL (ID FIELD)



The write precompensation circuitry, in the controller to the drive interface, reduces the effects one bit has on another. There are two parts to write precompensation logic, reduced write current (RWC) and shifting of the bits as they are written. The RWC is **NOT** controlled by the drive controller. The local microcontroller should specify when the write current is reduced by asserting its own RWC output.

The shifting of the data bits is controlled by the EARLY and LATE outputs. These two outputs should be used to delay the output as follows in Table 6:

| EARLY | LATE | DELAY              |
|-------|------|--------------------|
| 0     | 1    | no<br>delay        |
| 1     | 1    | one unit<br>delay  |
| 1     | 0    | two units<br>delay |

**TABLE 6. EARLY AND LATE DELAYS** 

The EARLY and LATE outputs are generated according to the rules in Tables 7 (RLL) and 8 (MFM or NRZ).

| RLL Cod           | _            |                   |         |
|-------------------|--------------|-------------------|---------|
| Preceding<br>Bits | Comp.<br>Bit | Following<br>Bits | Precomp |
| X 1 0 0           | 1            | 0 0 0 X           | EARLY   |
| X 0 0 0           | 1            | 0 0 0 X           | None    |
| X 0 0 0           | 1            | 0 0 1 X           | LATE    |
| 0 1 0 0           | 1            | 0 0 1 0           | None    |

TABLE 7. EARLY AND LATE GENERATION (RLL MODE)

FIGURE 5. PLL CONTROL (DATA FIELD)

**//** 

27-15

12/4/90

| MFM Coding - NRZ Data Pattern |   |   |   |                             |   |   |   |         |       |  |
|-------------------------------|---|---|---|-----------------------------|---|---|---|---------|-------|--|
| Preceding<br>Bits             |   |   | g | Comp. Following<br>Bit Bits |   |   |   | Precomp |       |  |
| X                             | Х | X | 1 | 1                           | 0 | Χ | Х | Х       | EARLY |  |
| X                             | X | Χ | 0 | 1                           | 1 | X | X | X       | LATE  |  |
| X                             | X | 0 | 0 | 0                           | 1 | X | X | Χ       | EARLY |  |
| Х                             | Х | 1 | 0 | 0                           | 0 | Х | х | X       | LATE  |  |

TABLE 8. EARLY AND LATE GENERATION (MFM - NRZ)

### 3.0 INTERFACE PORTS AND TASK FILES

#### 3.1 HOST INTERFACE ORGANIZATION

The WD42C22C's host interface directly connects to the IBM XT or IBM AT system bus as well as the system bus of any XT or AT compatible. The WD42C22C has high current drivers which allow it to be directly connected to the system bus.

The register configuration for the <u>host</u> interface is dependent on the state of the AT/XT control bit in the interface control register which is written by the local microcontroller.

There is an additional slave host mode. In this mode, the microcontroller communicates to a peripheral device with up to 32 registers through the host interface. The slave device can transfer data to/from the buffer RAM by using a slave DMA scheme such as the WD-BUS mode in the SBIC.

The sequence that the microcontroller follows to transfer data between the buffer RAM and the host is defined under the buffer manager description.

#### 3.2 XT HOST INTERFACE

To put the WD42C22C in the XT compatible interface mode the local microcontroller resets the AT/XT control bit. In this mode, HCS should be active when I/O ports 320 (hex) through 323 (hex) are addressed. (XT I/O ports 320 through 323 are primary ports. XT I/O ports 324 through 327 are

secondary ports. Unless otherwise noted, information regarding the primary ports is identical to information on secondary ports.) Table 9 lists the port descriptions for this mode.

| HA9 | HA2 | HA1 | HA0 | READ<br>PORT             | WRITE<br>PORT             |  |
|-----|-----|-----|-----|--------------------------|---------------------------|--|
| X   | Х   | 0   | 0   | Read data                | Write data                |  |
| X   | Χ   | 0   | 1   | Hardware<br>status       | Hardware reset            |  |
| X   | Χ   | 1   | 0   | Drive con-<br>figuration | Drive<br>select           |  |
| X   | X   | 1   | 1   | NOT<br>USED              | DMA and interrupt control |  |

**TABLE 9. XT PORT DESCRIPTIONS** 

### 3.2.1 Read Data Port (HA1 Through HA0 = 0, Read)

The read data port is used to send data and status to the host processor. The data read from this port comes from the buffer RAM under the control of the buffer manager.

### 3.2.2 Write Data Port (HA1 through HA0 = 0, Write)

The write data port is used to send commands and data from the host to the drive controller. The data is written to the buffer RAM under the control of the buffer manager.

### 3.2.3 Hardware Status (HA1 Through HA0 = 1, Read)

This port contains the controller hardware status. It can be read by the host at any time. Bit 7, bit 6, bit 2, and bit 1 are written by the local microcontroller. Bit 5, bit 4, bit 3, and bit 0 are controlled by internal logic. The bits are defined as follows:

|   |   | Bit |     |     |      |     |     |     |  |  |  |
|---|---|-----|-----|-----|------|-----|-----|-----|--|--|--|
| I | 7 | 6   | 5   | 4   | 3    | 2   | 1   | 0   |  |  |  |
|   | X | Х   | IRQ | DRQ | XBSY | C/D | 1/0 | REQ |  |  |  |

This bit signifies that an interrupt is pending. IRQ reflects the state of the INTRQ output. The INTRO pin is tristated and the IRO status bit and internal interrupt flip-flop are reset when the host disables the interrupt or when the WD42C22C is reset, either by the host or by asserting master reset.

#### 3.2.3.2 Bit 4 Dma Request

This bit signals that the WD42C22C is ready for a DMA transfer to take place. The direction of the transfer is determined by the I/O bit. This bit reflects the state of the DREQ output.

#### 3.2.3.3 Bit 3 XT Busy

This bit indicates that the WD42C22C is busy executing a command and is unable to accept another command. This bit is set by during a reset.

#### 3.2.3.4 Bit 2 Command / Data

This bit tells the host which type of transfer is expected at the read and write data ports. C/D set to 1 indicates that a command or status transfer is expected. C/D set to 0 indicates that a data transfer is expected.

#### 3.2.3.5 Bit 1 Input / Output

This bit tells the host the direction of transfer for the two data ports. I/O set to 1 indicates an input (read) by the host and I/O set to 0 indicates an output (write) by the host.

#### 3.2.3.6 Bit 0 Request

This bit is one of the handshaking signals between the host and WD42C22C. When transferring data to/from, the WD42C22C's read data and write data ports by the host, assertion of this bit informs the host that the WD42C22C is ready for the transfer.

#### 3.2.4 Controller Reset (HA1 through **HA0 = 1. Write)**

When this port is written, regardless of the data written, the RESET output is asserted if enabled. If the reset has been disabled by the local microcontroller, then writing to this port asserts MCINT and the local microcontroller is responsible for resetting the logic on the drive controller board.

#### 3.2.5 Drive Configuration Information (HA1 through HA0 = 2, Read)

This register, when read, informs the host about the configuration of the drive(s) attached. This configuration information is written by the local microcontroller.

#### 3.2.6 Controller Select (HA1 through HA0 = 2, Write)

When this port is written, regardless of the data written, the MCINT output is asserted to inform the local microcontroller that the controller board has been selected.

#### 3.2.7 DMA and Interrupt Mask (HA1 through HA0 = 3, Write)

This port enables or disables the DMA and interrupt to the host. When IRQEN is set to 1, then interrupts to the host are enabled. This bit is cleared when the WD42C22C is reset. The INTRQ line is tristated and the host interrupt is cleared when the interrupts are disabled. When DRQEN is set to 1, then DMA requests to the host are enabled. This bit is cleared when the WD42C22C is reset.

|   |   |   | Bit |   |   |           |           |
|---|---|---|-----|---|---|-----------|-----------|
| 7 | 6 | 5 | 4   | 3 | 2 | 1         | 0         |
| Х | Х | X | X   | X | X | IRQ<br>EN | DRQ<br>EN |

| ABSY | HA9 | HA2 | HA1 | HA0     | READ<br>PORT                 | WRITE<br>PORT             |
|------|-----|-----|-----|---------|------------------------------|---------------------------|
|      |     |     |     | AT TASE | K FILE COPY                  |                           |
| 0    | 0   | 0   | 0   | 0       | Read Data                    | Write Data                |
|      |     |     |     |         | (16 bits)                    | (16 bits)                 |
| 0    | 0   | 0   | 0   | 1       | Host Error<br>Register       | Write Precomp<br>Cylinder |
| 0    | 0   | 0   | 1   | 0       | Sector Count                 | Sector Count              |
| 0    | 0   | 0   | 1   | 1       | Sector Number                | Sector Number             |
| 0    | 0   | 1   | 0   | 0       | Cylinder Number<br>Low       | Cylinder Number<br>Low    |
| 0    | 0   | 1   | 0   | 1       | Cylinder Number<br>High      | Cylinder Number<br>High   |
| 0    | 0   | 1   | 1   | 0       | SDH                          | SDH                       |
| 0    | 0   | 1   | 1   | 1       | Host Status<br>Register      | Host Command<br>Register  |
| 1    | 0   | X   | X   | Χ       | Host Status Register         | INVALID                   |
|      |     |     |     | CONTE   | ROL PORTS                    |                           |
| X    | 1   | 1   | 1   | 0       | Alternate Status<br>Register | Fixed Disk<br>Register    |
| Χ    | 1   | 1   | 1   | 1       | Digital Input Register*      | NOT USED                  |

<sup>\*</sup>Bit 7 is tristated when the digital input register is read to accomodate the floppy disk change status.

**TABLE 10. AT MODE PORT DESCRIPTIONS** 

#### 3.3 AT HOST INTERFACE

To put the WD42C $\underline{22}$ C in the AT compatible interface mode, the AT/XT $\underline{\phantom{0}}$ control bit is set by the local microcontroller. The HCS chip select should be active when I/O ports 1F0 $_{16}$  through 1F7 $_{16}$  and 3F6 $_{16}$  and 3F7 $_{16}$  are addressed for primary addressing and for I/O ports 170 $_{16}$  through 177 $_{16}$  and 376 $_{16}$  and 377 $_{16}$  for secondary addressing. Only address signals HA8 through HA3 and AEN need to be decoded to generate HCS. Table 10 describes the ports for AT mode as follows:

When port 0 is accessed the IOCS16 output is asserted when in AT programmed I/O mode. All buffer data transfers are 16 bits. The ECC byte transfers in a long mode (read or write) are 8 bit transfers. All other register transfers are 8 bits.

Registers 1 through 7 are an identical copy of the drive controller task registers 1 through 7. These registers can be read or written by the host only when the ABSY status bit is not active. Any attempt by the host to read the AT task file copy while ABSY is active results in the host status register being read. The AT task file copy registers cannot be written by the host while ABSY is active.

#### 27

### 3.3.1 Error Register (HA9, HA2 through HA0 = 01, Read)

The error register is read only and contains the specific error status pertaining to a command. The meaning of the status register bits are as follows:

|    |             |   | Bit  |   |    |     |      |
|----|-------------|---|------|---|----|-----|------|
| 7  | 6           | 5 | 4    | 3 | 2  | 1   | 0    |
| BB | CRC/<br>ECC | 0 | IDNF | 0 | AC | TK0 | DMNF |

#### 3.3.1.1 Bit 7 Bad Block

A bad block address mark has been detected when trying to read or write that sector. The data field will not be read or written.

#### 3.3.1.2 Bit 6 CRC/ECC Data Field Error

An uncorrectable ECC error or a CRC error was detected in the data field.

#### 3.3.1.3 Bit 5 Reserved

Not used, forced to zero.

#### 3.3.1.4 Bit 4 ID Not Found

Occurs when cylinder, head, sector, size parameters with a correct ID field CRC cannot be found. For read and write sector commands, with the retry disable bit reset, this bit indicates that after 10 index pulses, an auto-scan ID and auto-seek, and 10 more index pulses, no matching ID field was found. If the retry disable bit is set, then no matching ID field was found after 2 index pulses; no auto-scan or auto-seek is performed.

#### 3.3.1.5 Bit 3 Reserved

Not used, forced to zero.

#### 3.3.1.6 Bit 2 Aborted Command

Set if command was started and one of the following conditions occurred:

- 1. Drive not ready
- · 2. Write fault
- 3. Illegal command code.

#### 3.3.1.7 Bit 1 Track 0 Error

This bit, when set, indicates an error detecting Track 0 during a restore.

#### 3.3.1.8 Bit 0 Data Address Mark Not Found

Set if the first two bytes of the data field following an ID match are not A1 F8. This condition is checked for read sector commands only.

### 3.3.2 Write Precomp Cylinder Register (HA9, HA2 Thru HA0 = 01, Write)

This register is used to control the Reduce Write Current (RWC) signal going to the drive. RWC is turned on if the present position cylinder number is greater than or equal to the 4 times the write precomp cylinder number. If the write precomp cylinder number is FF<sub>16</sub>, then the RWC is never asserted.

### 3.3.3 Sector Count (HA9, HA2 through HA0 = 02, Read/Write)

This register is used in read sector, write sector, and format commands to implement multiple sector handling with one command. A value of 1 indicates a single sector transfer, a value of 2 indicates a 2 sector transfer, and so forth. A value of 0 indicates a 256 sector transfer. Sector count is decremented and the sector number is incremented after each sector transfer between the buffer and host or drive.

### 3.3.4 Sector Number (HA9, HA2 through HA0 = 03, Read/Write)

The sector number register is used to hold the number of the desired sector for read and write commands. The sector number can range from 0 to 255.

//

12/4/90

# 3.3.5 Cylinder Number Low And High Registers (Cylinder Number Low: HA9, HA2 through HA0 = 04, Read/Write. Cylinder Number High: HA9, HA2 through HA0 = 05, Read/Write)

These registers specify the cylinder number for read, write, and format commands. The cylinder number may range in value from 0 to 2047. Cylinder number low register holds the 8 least significant bits of the desired cylinder number. Cylinder number high register holds the three most significant bits of the desired cylinder number in bits 0 through 2. Bits 3 through 7 are not normally used in disk controller boards. These bits are latched when writing to this register. This means that all 8 bits can be used to transfer information between the host and the local microcontroller.

### 3.3.6 SDH Register (HA9, HA2 through HA0 = 06, Read/Write)

This register is used to specify the desired drive and head numbers and to specify CRC or ECC mode.

|             |   |    | Bit             |      |      |      |   |
|-------------|---|----|-----------------|------|------|------|---|
| 7           | 6 | 5  | 4               | 3    | 2    | 1    | 0 |
| CRC/<br>ECC | 0 | SS | Drive<br>Number | Head | d Nu | mber |   |

#### 3.3.6.1 Bit 7 ECC/CRC Select

This bit is set for data field ECC mode. It is reset for data field CRC mode.

#### 3.3.6.2 Bit 5 Sector Size

Bit 5 (SS0) is used to select sector size. If SS0 = 0, then the sector size is 256 bytes and if SS0 = 1, then the sector size is 512 bytes.

#### 3.3.6.3 Bit 4 Drive Select

Bit 4 specifies the desired drive number. This bit also determines which of the two internal drive status registers are read when the host accesses the host status register or alternate status register. If DS = 0, the host receives drive zero

status. If DS = 1, then the host receives drive one status

#### 3.3.6.4 Bits 3 through 0 Head Number

Bits 3, 2, 1 and 0 specify the desired head number.

### 3.3.7 Host Status Register (HA9, HA2 through HA0 = 7, Read)

The status register reads only and reflects the status of the controller as well as the status of certain drive control lines. Some of the status bits are controlled by the local microcontroller. Drive status comes from two registers in the WD42C22C, one for each drive. Bit 4 of the SDH register in the AT task file copy controls which of the two registers is read when the host reads this port. Reading of the status register by the host resets INTRQ. The description of the status register bits follows:

|      | Bit |    |    |     |     |     |     |  |  |  |  |
|------|-----|----|----|-----|-----|-----|-----|--|--|--|--|
| 7    | 6   | 5  | 4  | 3   | 2   | 1   | 0   |  |  |  |  |
| ABSY | RDY | WF | SC | DRQ | DWC | IDX | ERR |  |  |  |  |

#### 3.3.7.1 Bit 7 AT Busy

This bit is set to 1 when the controller is accessing the disk. ABSY is activated by the start of a command (writing into the host command register). It is deactivated at end of all commands by the local microcontroller. This bit is also set during a reset.

#### 3.3.7.2 Bit 6 Drive Ready

This bit reflects the state of the DRDY drive status pin. Any command aborts if DRDY is low. This bit is written by the local microcontroller.

#### 3.3.7.3 Bit 5 Write Fault

This bit reflects the state of the WF drive status pin. Any command aborts if WF is high. This bit is written by the local microcontroller.

#### 3.3.7.4 Bit 4 Seek Complete

This bit reflects the state of the SC signal coming from the drive. This bit is written by the local microcontroller.

#### 3.3.7.5 Bit 3 Data Request

This bit is asserted when the host should be transferring data between the RAM buffer and host. This bit is controlled by the buffer manager.

#### 3.3.7.6 Bit 2 Data Was Corrected

This bit indicates that an error in the data field was detected and corrected. The buffer contains corrected data. This bit is written by the local microcontroller.

#### 3.3.7.7 Bit 1 Index

This bit reflects the state of the INDEX pin.

#### 3.3.7.8 Bit 0 Error

This bit indicates that a non-recoverable error has occurred. The error register describes the error condition when this bit is active. This bit is written by the local microcontroller.

### 3.3.8 Host Command Register (HA9, HA2 through HA0 = 7, Write)

The command to be executed is written into this register. Writing this register sets ABSY in the status register and asserts the MCINT pin going to the local microcontroller. The command latches in a register which the local microcontroller reads. Writing this register resets INTRQ.

### 3.3.9 Alternate Status Register (HA9, HA2 through HA0 = E, Read)

This register is the same as the host status register (7) but mapped at a different address. Refer to page 23 for the bit description.

### 3.3.10 Fixed Disk Register (HA9, HA2 through HA0 = E. Write)

The fixed disk register is used by the host to control some of the internal functions of the WD42C22C. Bit 0 and bits 4 through bit 7 are reserved for future definition. These bits are currently not used in the AT protocol but they are implemented in the WD42C22C, i.e. the fixed disk register passes 8 bits between the host and the local microcontroller. The host should write zeroes to these bits in AT mode. The fixed disk register is coded as follows:

|   | Bit |   |   |       |       |     |   |  |  |  |  |  |
|---|-----|---|---|-------|-------|-----|---|--|--|--|--|--|
| 7 | 6   | 5 | 4 | 3     | 2     | 1   | 0 |  |  |  |  |  |
| 0 | 0   | 0 | 0 | HS3EN | N RST | ĪEN | 0 |  |  |  |  |  |

#### 3.3.10.1 Bit 3 Head Select 3 Enable

When HS3EN = 1, then HEAD SELECT 3 is asserted by the local microcontroller. When HS3EN = 0, then RWC is asserted by the local microcontroller.

#### 3.3.10.2 Bit 2 Reset

Writing a 1 to this bit resets the WD42C22C. The RESET output is asserted and remains asserted until this bit is written back to 0. This bit must be on for a minimum of 5.0  $\mu s$ . If reset has been disabled by the local microcontroller then writing a '1' to this bit only resets the WD42C22C. RESET is not asserted in this case. The WD42C22C asserts MCINT and the local microcontroller is responsible for resetting the drive controller board logic.

#### 3.3.10.3 Bit 1 Interrupt Enable

When IEN = 0, then the INTRQ output to the host is enabled. When IEN = 1, then the INTRQ output to the host is disabled. Disabling interrupts does NOT reset an existing interrupt but inhibits all further interrupts. Any interrupts pending when this bit is set causes the INTRQ output to be asserted. A system master reset does NOT affect the IEN bit but resets any existing interrupt. The internal power qualified reset sets IEN to 0. When interrupts are disabled, then the INTRQ pin is tristated.

1/2

12/4/90

| A<br>D<br>7 | A<br>D<br>6 | A<br>D<br>5 | A<br>D<br>4 | A<br>D<br>3 | A<br>D<br>2 | A<br>D<br>1 | A<br>D<br>0 | READ PORT                  | WRITE PORT                 |
|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|----------------------------|----------------------------|
| DIS         | SK          | CC          | TN          | RC          | DLL         | .EF         | ₹ T/        | ASK FILE                   |                            |
| 0           | 0           | 0           | Х           | Χ           | Χ           | Χ           | Χ           | BUS TRISTATE               | NOT USED                   |
| 0           | 0           | 1           | 0           | 0           | 0           | 0           | 0           | INVALID                    | INVALID                    |
| 0           | 0           | 1           | 0           | 0           | 0           | 0           | 1           | Error Register             | PLO Length                 |
| 0           | 0           | 1           | 0           | 0           | 0           | 1           | 0           | Sector Count               | Sector Count               |
| 0           | 0           | 1           | 0           | 0           | 0           | 1           | 1           | Sector Number              | Sector Number              |
| 0           | 0           | 1           | 0           | 0           | 1           | 0           | 0           | Cylinder Number Low        | Cylinder Number Low        |
| 0           | 0           | 1           | 0           | 0           | 1           | 0           | 1           | Cylinder Number High       | Cylinder Number High       |
| 0           | 0           | 1           | 0           | 0           | 1           | 1           | 0           | SDH                        | SDH                        |
| 0           | 0           | 1           | 0           | 0           | 1           | 1           | 1           | Status Register            | Command Register           |
| хт          |             |             |             |             |             |             |             |                            |                            |
| 0           | 0           | 1           | 0           | 1           | 1           | 0           | 1           | Hardware Status            | Hardware Status            |
| 0           | 0           | 1           | 0           | 1           | 1           | 1           | 0           | NOT USED                   | Drive Configuration        |
| BU          | IFF         | ER          | M           | AN          | AG          | ER          | ł           |                            |                            |
| 0           | 0           | 1           | 1           | 0           | 0           | 0           | 0           | Host Buffer Pointer Low    | Host Buffer Pointer Low    |
| 0           | 0           | 1           | 1           | 0           | 0           | 0           | 1           | Host Buffer Pointer High   | Host Buffer Pointer High   |
| 0           | 0           | 1           | 1           | 0           | 0           | 1           | 0           | Host Transfer Count Low    | Host Transfer Count Low    |
| 0           | 0           | 1           | 1           | 0           | 0           | 1           | 1           | Host Transfer Count High   | Host Transfer Count High   |
| 0           | 0           | 1           | 1           | 0           | 1           | 0           | 0           | Disk Buffer Pointer Low    | Disk Buffer Pointer Low    |
| O           | 0           | 1           | 1           | 0           | 1           | 0           | 1           | Disk Buffer Pointer High   | Disk Buffer Pointer High   |
| 0           | 0           | 1           | 1           | 0           | 1           | 1           | 0           | Microcontroller RAM Access | Microcontroller RAM Access |
| 0           | 0           | 1           | 1           | 0           | 1           | 1           | 1           | Buffer Status              | Buffer Control             |

TABLE 11. LOCAL MICROCONTROLLER REGISTER MAP

### 3.3.11 Digital Input Register (HA9, HA2 through HA0 = F, Read)

The digital input register is used by the host to determine the state of WRITE GATE and the drive selects and head selects. Bit 5 is written by the local microcontroller when HS3EN (bit 3 of the fixed disk register) is set to zero. Bit 5 comes from bit 3 of the host SDH register with HS3EN set to one. Bits 0 through bit 4 also come from the host SDH register. When this register is read by the host, then HD7 (pin 82) is tristated. It is coded as follows:

|   |    |             | Bi  | t   |     |     |     |
|---|----|-------------|-----|-----|-----|-----|-----|
| 7 | 6  | 5           | 4   | 3   | 2   | 1   | 0   |
| X | WG | HS3/<br>RWC | HS2 | HS1 | HS0 | DS2 | DS1 |

| A<br>B<br>S<br>Y | A<br>D<br>7 | A<br>D<br>6 | A<br>D<br>5 | A<br>D<br>4 | A<br>D<br>3 | A<br>D<br>2 | A<br>D<br>1 | A<br>D<br>O | READ PORT                    | WRITE PORT                    |
|------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------------------------|-------------------------------|
| MIS              | SC.         |             |             |             |             |             |             |             |                              |                               |
| Χ                | 0           | 0           | 1           | 1           | 1           | 0           | 0           | 0           | Interface Status             | Interface Control             |
| Х                | 0           | 0           | 1           | 1           | 1           | 0           | 0           | 1           | Configuration Status Low     | Not Used                      |
| Х                | 0           | 0           | 1           | 1           | 1           | 0           | 1           | 0           | Configuration Status High    | Not Used                      |
| Χ                | 0           | 0           | 1           | 1           | 1           | 0           | 1           | 1           | Drive Interface Status       | Drive Interface Control       |
| Χ                | 0           | 0           | 1           | 1           | 1           | 1           | 0           | 0           | Alternate Sector Number      | Not Used                      |
| ΑТ               | IN.         | ΓΕΙ         | RF/         | <b>AC</b> I | E           |             |             |             |                              |                               |
| Х                | 0           | 0           | 1           | 0           | 1           | 0           | 1           | 0           | AT Control Register          | AT Control Register           |
| Х                | 0           | 0           | 1           | 1           | 1           | 1           | 0           | 1           | Drive 0 Status               | Drive 0 Status                |
| Х                | 0           | 0           | 1           | 1           | 1           | 1           | 1           | 0           | Drive 1 Status               | Drive 1 Status                |
| Χ                | 0           | 0           | 1           | 1           | 1           | 1           | 1           | 1           | Fixed Disk Register          | Digital Input Register        |
| ΑТ               | IN'         | ΓΕΙ         | RF/         | AC!         | E (         | TAS         | SK          | FIL         | E COPY)                      |                               |
| 1                | 0           | 1           | 0           | 0           | 0           | 0           | 0           | 1           | Write Precomp Cylinder       | Error Register                |
| 1                | 0           | 1           | 0           | 0           | 0           | 0           | 1           | 0           | Sector Count                 | Sector Count                  |
| 1                | 0           | 1           | 0           | 0           | 0           | 0           | 1           | 1           | Sector Number                | Sector Number                 |
| 1                | 0           | 1           | 0           | 0           | 0           | 1           | 0           | 0           | Cylinder Number Low          | Cylinder Number Low           |
| 1                | 0           | 1           | 0           | 0           | 0           | 1           | 0           | 1           | Cylinder Number High         | Cylinder Number High          |
| 1                | 0           | 1           | 0           | 0           | 0           | 1           | 1           | 0           | SDH                          | SDH                           |
| 1                | 0           | 1           | 0           | 0           | 0           | 1           | 1           | 1           | Command Register (from Host) | Not Used                      |
| SL               | AVI         | E F         | 109         | ST.         |             |             |             |             |                              |                               |
| 0                | 0           | 1           | 0           | 0           | 0           | Χ           | Χ           | Χ           | Invalid                      | Invalid                       |
| Х                | 0           | 1           | 0           | 0           | 1           | 0           | 0           | 0           | Invalid                      | Slave Address Port for reads  |
| Х                | 0           | 1           | 0           | 0           | 1           | 0           | 0           | 1           | Slave Read Data              | Slave Write Data              |
| Х                | 0           | 1           | 0           | 0           | 1           | 0           | 1           | 0           | Invalid                      | Slave Address Port for writes |
| Χ                | 0           | 1           | 0           | 0           | 1           | Χ           | Χ           | Χ           | Invalid                      | Not Used                      |
| Χ                | 0           | 1           | 0           | 1           | Χ           | Χ           | Χ           | Χ           | Invalid                      | Not Used                      |
| Χ                | 0           | 1           | 1           | Χ           | Χ           | Χ           | Χ           | Χ           | Bus Tristate                 | Not Used                      |
| <br>Х            | 1           | Х           | Х           | Х           | Х           | Х           | Х           | X           | Bus Tristate                 | Not Used                      |

TABLE 11. LOCAL MICROCONTROLLER REGISTER MAP (CONT'D)

#### 3.3.11.1 Bit 6 Write Gate On

This bit reflects the state of the  $\overline{\text{WG}}$  output pin.

#### 3.3.11.2 Bit 5 Head Select 3/ Reduce Write Current

This bit reflects the state of the HS3/RWC drive control output. The RWC bit is written

**//**/

12/4/90 27-23

by the local microcontroller.  $\overline{\text{HS3}}$  comes from the SDH register bit 3.

#### 3.3.11.3 Bit 4, Bit 3, And Bit 2 Head Selects

These bits reflect the states of the HS2, HS1, HS0, and drive control outputs respectively. These bits are controlled by SDH register bits 2 through 0 respectively.

#### 3.3.11.4 Bit 1 And Bit 0 Drive Selects

These bits indicate which drive is currently being selected by the host. They are controlled by the SDH register bit 4.

#### 3.4 SLAVE HOST INTERFACE

In slave mode, the WD42C22C host interface can be hooked up to a peripheral device such as the WD33C93 (SBIC). The microcontroller reads and writes the peripheral device through the WD42C22C using the ports as follows:

| A<br>B<br>S<br>Y | <b>A</b><br>D<br>7 | A<br>D<br>6 | A<br>D<br>5 | A<br>D<br>4 | D | _ | D | <b>A</b> D 0 | READ<br>PORT          | WRITE<br>PORT                          |
|------------------|--------------------|-------------|-------------|-------------|---|---|---|--------------|-----------------------|----------------------------------------|
| X                | 0                  | 1           | 0           | 0           | 1 | 0 | 0 | 0            | Bus tri-<br>state     | Slave<br>address<br>port for<br>reads  |
| ×                | 0                  | 1           | 0           | 0           | 1 | 0 | 1 | 0            | Bus tri-<br>state     | Slave<br>address<br>port for<br>writes |
| X                | 0                  | 1           | 0           | 0           | 1 | 0 | 0 | 1            | Slave<br>read<br>data | Slave<br>write<br>data                 |

The slave peripheral connects to the WD42C22C using an ALE type interface. Register reads and writes are always 8-bit. The procedure to read or write a slave peripheral register is to first write the register number to the slave address port before the register contents are read or written. This address must always be written before each register access even when consecutively accessing the same register two or more times.

Data transfers between the peripheral device and the WD42C22C are WD-bus mode and can be either 8-bit or 16-bit and is controlled by the H16/8 bit (bit 1 of the auxilliary buffer control register). The slave mode is enabled by the HSMB bit (bit 6 of the auxilliary buffer control register).

### 3.5 LOCAL MICROCONTROLLER INTERFACE ORGANIZATION

The local microcontroller controls the host interface mode (AT or XT) and controls the buffer manager and the drive controller. The local microcontroller is usually in a sleep state until it is told to do something by the assertion of the MCINT output. In the XT mode, MCINT is asserted when the controller is selected. In the AT mode, MCINT is asserted when the host writes to the command register. In slave host mode, MCINT is asserted when the slave peripheral device asserts its INTRQ signal. MCINT is also asserted at the end of each host or disk transfer regardless of the interface mode.

The local microcontroller can have either the Intel-type (8051) or the Motorola-type (68HC11) interface. The WD42C22C has a built-in MOtorola-inTEL (MOTEL) circuit which can sense the processor interface type and can therefore be directly interfaced to either type processor.

Table 11 lists the register map for the local microcontroller.

### 3.6 DISK CONTROLLER TASK FILE (AD7 THROUGH AD0 = 20 THRU 27)

### 3.6.1 Error Register (AD7 through AD0 = 21, READ)

The error register reads only and contains the specific error status pertaining to a command. The meaning of the status register bits are as follows:

|    |             | -    | Bit  |   |    |   |      |
|----|-------------|------|------|---|----|---|------|
| 7  | 6           | 5    | 4    | 3 | 2  | 1 | 0    |
| BB | CRC/<br>ECC | RIDF | IDNF | 0 | AC | 0 | DMNF |

27-24

12/4/90

//

### 27

#### 3.6.1.1 Bit 7 Bad Block

A bad block address mark has been detected when trying to read or write that sector. The data field is not be read or written.

#### 3.6.1.2 Bit 6 CRC/ECC Data Field Error

A CRC error in the data field has been detected when in CRC mode. In ECC mode, data errors were detected in the data.

#### 3.6.1.3 Bit 5 Relocation ID Found

This bit is set if a relocation ID is found after detecting the bad block mark in the desired sector's ID field. This bit is only valid if the R option is used in the set parameter command.

#### 3.6.1.4 Bit 4 ID Not Found

Occurs when cylinder, head, sector, size parameters with a correct ID field CRC cannot be found. For a scan ID command, this bit is set after 10 index pulses if the retry disable bit is not set. Otherwise, IDNF is set after 2 index pulse if no ID was found. For read and write sector commands with the retry disable bit set, this bit indicates that after 10 index pulses, auto-scan ID and auto-seek, and 10 more index pulses, no matching ID field was found. If the retry disable bit is set and no matching ID field was found after 2 index pulses, then no auto-scan or auto-seek is performed.

#### 3.6.1.5 Bit 3 Reserved

Not used, forced to zero.

#### 3.6.1.6 Bit 2 Aborted Command

Set if command was started and one of the following conditions occurred:

- · Drive not ready
- · Write fault
- Illegal command code.

#### 3.6.1.7 Bit 1 Reserved

Not used in WD42C22C, forced to zero.

#### 3.6.1.8 Bit 0 Data Address Mark Not Found

Set if the first two bytes of the data field following an ID match are not A1 F8. This condition is checked for read sector commands only.

### 3.6.2 PLO Length Register (AD7 through AD0 = 21, Write)

This register is used for two purposes:

- To determine the length of the Data PLO sync field during write commands and to determine the length of the ID PLO sync field dur-ing format commands. The contents of this register regulates the PLO field size in all data coding modes.
- To load a value in the internal GAP register. During the load parameter block command. the contents of the lower six bits of the PLO length register are transferred to the internal GAP register. In hard sector NRZ (ESDI) mode, this internal GAP register is used to control the delay between the INDEX or SEC-TOR pulse and the leading edge of READ GATE. In hard sector MFM or RLL mode, this internal GAP register is used to control the delay between the INDEX or SECTOR pulse and the falling edge of the internally generated DRUN signal. In hard sector MFM or RLL mode. RG is asserted 2 byte times after INDEX or SECTOR. This GAP register is altered by loading the desired GAP register value into the PLO length register and then issuing a load parameter block command.

### 3.6.3 Sector Count (AD7 through AD0 = 22, Read/Write)

|       | Bit   |      |      |       |      |      |   |  |  |  |  |  |
|-------|-------|------|------|-------|------|------|---|--|--|--|--|--|
| 7     | 6     | 5    | 4    | 3     | 2    | 1    | 0 |  |  |  |  |  |
| N     | IUMBE | R OF | SECT | ORS/G | AP V | ALUE | = |  |  |  |  |  |
| - ' ' |       |      | WITH |       |      |      | - |  |  |  |  |  |

This register is used for three purposes:

The sector count register is used in read sector, write sector, and format commands to implement multiple sector handling with one command. A value of 1 indicates a single sector transfer, a value of 2 indicates a 2 sector transfer, and so forth. A value of 0 indicates a 256 sector transfer. Sector count decrements and

//

12/4/90 27-25

sector number increments after each sector transfer to or from the buffer.

- To load a value into the internal gap value register. During the load parameter block command the contents of this register are transferred into an internal gap value register. This gap value register specifies the data byte written into the gaps during format commands.
- To specify to the microcontroller the sector number where a bad block bit was detected if relocation ID searches are enabled. If the R option is set in a set parameter command, then during read and write commands if a bad block is detected, the WD42C22C searches for a special ID field containing relocation information. When the command terminates due to a bad block, then the sector number of the sector with the bad block is returned to the microcontroller in this register. This is true whether or not the relocation information is detected.

### 3.6.4 Sector Number (AD7 Thru AD0 = 23, Read/Write)

| Bit |   |            |   |   |   |   |  |  |  |  |
|-----|---|------------|---|---|---|---|--|--|--|--|
| 0   | 1 | 3 2        | 4 | 5 | 6 | 7 |  |  |  |  |
|     | 1 | <b>3 2</b> | 4 | 5 | 6 | 7 |  |  |  |  |

The sector number register has three uses:

- To hold the number of the desired sector for read and write commands. The sector number can range from 0 to 255.
- To control the Gap 1 and Gap 3 sizes during format commands. The sector number holds the number of gap bytes minus three for format (number of gap bytes minus six for NRZ mode).
- To load a value into the internal pad value register. During the load parameter block command, the contents of this register are transferred into an internal pad value register. This pad value register specifies the data byte written into the ID and DATA pads during format and write commands

## 3.6.5 Cylinder Number Registers (Cylinder Number Low: AD7 through AD0 = 24, Read Write Cylinder Number High: AD7 through AD0 = 25. Read/Write)

This register has two functions:

- To specify the cylinder number for read, write, and format commands. The cylinder number may range in value from 0 to 2047.
- The cylinder number register is used during a load parameter block command to specify the desired sector size if a non-standard sector size is desired and to specify the offset for a write ID command. To load the internal sector size register, write in the desired sector size into the cylinder registers. Next, issue a load parameter block command. Set U=1 to enable the programmable sector size or programmable write ID offset.

# 3.6.6 Cylinder Number Registers (Cylinder Number Low: AD7 through AD0 = 24, Read/Write Cylinder Number High: AD7 through AD0 = 25, Read/Write)

Cylinder number low register holds the 8 least significant bits of the desired cylinder number or the 8 least significant bits of the desired sector size.

Cylinder number high register holds the three most significant bits (bits 0 through 2) of the desired cylinder number or the three most significant bits of the desired sector size. Bits three through seven of the cylinder number high register are not used and must be set to zero.

### 3.6.7 SDH Register (AD7 through AD0 = 26, Read/Write)

This register is used to specify the desired drive and head numbers and to specify CRC or ECC mode. There are two SDH modes available, three or four bit head number. Three bit head mode is the default after a master reset. Setting the H bit in the set parameter command engages the four bit head mode.

#### 3.6.7.1 SDH Register, Three-Bit Head Number

| Bit         |     |     |   |   |    |     |   |  |  |  |
|-------------|-----|-----|---|---|----|-----|---|--|--|--|
| 7           | 6   | 5   | 4 | 3 | 2  | 1   | 0 |  |  |  |
| CRC/<br>ECC | SS1 | SS0 | 0 | 0 | He | ad# |   |  |  |  |

#### 3.6.7.2 SDH Register, Four-Bit Head Number

|             |     |     | Bit |     |     |   |   |
|-------------|-----|-----|-----|-----|-----|---|---|
| 7           | 6   | 5   | 4   | 3   | 2   | 1 | 0 |
| CRC/<br>ECC | SS1 | SS0 | 0   | Hea | ad# |   |   |

#### 3.6.7.3 Bit 7 ECC/CRC Select

This bit is set for data field ECC mode. It is reset for data field CRC mode. In RLL mode, this bit is ignored. RLL mode always uses 7-byte ECC. The CRC/ECC flag bit is not written on the disk at format time. The bad block flag is written on the disk in its place.

#### 3.6.7.4 Bit 6 and Bit 5 Sector Size

Bits 6 and 5 contain sector size bits. These bits are written on the disk at format time. These bits should be 0 if programmable sector size is used. These bits are reserved for special flags in programmable sector size mode. The possible sector sizes and their selection codes are as follows:

| SS1 | SS0 | Sector Size          |
|-----|-----|----------------------|
| 0   | 0   | 256 byte data field  |
| 0   | 1   | 512 byte data field  |
| 1   | 0   | 1024 byte data field |
| 1   | 1   | 128 byte data field  |

The sector sizes can be optionally specified to be any value between 100 and 2048 bytes by using the load parameter block command. The user is responsible for validating the effectiveness of the ECC for sector sizes over 1056 bytes.

### 3.6.7.5 Bit 4 and Bit 3 Reserved Bit 4 Drive Number Reserved

Reserved, Set to 0.

## 3.6.7.6 Bit 2, Bit 1, And Bit 0 Three Bit Head Number Bit 3, Bit 2, Bit 1, And Bit 0 Four Bit Head Number

Bits 2, 1, and 0 specify the desired head number in the three bit mode. Bits 3, 2, 1, and 0 specify the desired head number in four bit mode. The local microcontroller is responsible for outputting these bits to the drive.

#### NOTE

These bits are written on the disk at format time. The SDH byte written in the ID field during a format command is NOT the same as the SDH register. The SDH format byte is shown below:

### 3.6.7.7 SDH ID Field Format Byte (Three Bit Head Mode)

|              |     |     | Bit |   |     |     |   |
|--------------|-----|-----|-----|---|-----|-----|---|
| 7            | 6   | 5   | 4   | 3 | 2   | 1   | 0 |
| Bad<br>Block | SS1 | SS0 | 0   | 0 | Hea | ad# |   |

### 3.6.7.8 SDH ID Field Format Byte (Four Bit Head Mode)

| Bit          |     |     |   |     |     |   |   |  |  |
|--------------|-----|-----|---|-----|-----|---|---|--|--|
| 7            | 6   | 5   | 4 | 3   | 2   | 1 | 0 |  |  |
| Bad<br>Block | SS1 | SS0 | 0 | Hea | ad# |   |   |  |  |

### 3.6.8 Status Register (AD7 through AD0 = 27, Read)

The status register is read only and reflects the status of the controller as well as the status of certain drive control lines. If command in progress (bit 1) is set then no other register reads are valid and none of the other register bits are valid. The status register contents are returned for any read and all writes are disabled. The description of the

**//**/

12/4/90 27-27

status register bits follows:

|   | Bit |    |   |   |   |   |     |  |  |  |  |
|---|-----|----|---|---|---|---|-----|--|--|--|--|
| 7 | 6   | 5  | 4 | 3 | 2 | 1 | 0   |  |  |  |  |
| 0 | RDY | WF | 1 | 0 | 0 | 0 | ERR |  |  |  |  |

#### 3.6.8.1 Bit 7 Always 0

This bit is always zero when the microcontroller has access to this status register.

#### 3.6.8.2 Bit 6 Drive Ready

This bit reflects the status of the DRDY. Any command aborts if DRDY is low.

#### 3.6.8.3 Bit 5 Write Fault

This bit reflects the state of the WF pin. Any command aborts if WF is high.

#### 3.6.8.4 Bit 4 Always 1

This bit reflects the state of the SC input to the drive controller. This signal is internally tied to Vnn.

#### 3.6.8.5 Bit 3 Always 0

This bit reflects the state of the BDRQ signal that goes between the drive controller and the buffer manager. It is always zero when the microcontroller has access to this status register.

#### 3.6.8.6 Bit 2 Not Used

Forced to 0

#### 3.6.8.7 Bit 1 Always 0

This bit reflects the state of the command in progress signal in the drive controller. It is always zero when the microcontroller has access to this status register.

#### 3.6.8.8 Bit 0 Error

This bit indicates that a non-recoverable error has occurred. The error register describes the error condition when this bit is asserted.

Drive ready and write fault bits reflect the state of their associated input pins. The states of these status register bits are latched at the end of the command and are unlatched after the first status register read. Reading the status register results in the disk controller interrupt being reset.

### 3.6.9 Command Register (AD7 through AD0 = 27, Write)

The command to be executed is written into this register. Writing this register sets the internal BUSY and CIP signals and causes the controller to start executing the desired command. Writing this register resets the disk controller interrupt (DCI bit in the interface status register).

#### 3.7 XT INTERFACE PORTS

### 3.7.1 XT Host Hardware Status (AD7 through AD0 = 2D, Read/Write)

Bits 7, 6, 2, and 1 of this register are written by the local microcontroller and read by the host. The other bits reflect the state of certain hardware signals. This register is readable and valid in all host modes.

|   | Bit |   |     |     |      |                  |     |     |  |  |  |
|---|-----|---|-----|-----|------|------------------|-----|-----|--|--|--|
| Ι | 7   | 6 | 5   | 4   | 3    | 2                | 1   | 0   |  |  |  |
| I | 1   | 1 | IRQ | DRQ | XBSY | $C/\overline{D}$ | I/O | REQ |  |  |  |

#### 3.7.1.1 Bits 6 And 7 Undefined

These bits are currently undefined in the XT protocol and read as 1.

#### 3.7.1.2 Bit 5 Interrupt Request

This bit reflects the state of the INTRQ output. This bit can NOT be written by the microcontroller.

12/4/90

#### 3.7.1.3 Bit 4 DMA Request

This bit reflects the state of the DREQ output. This bit can NOT be written by the microcontroller.

#### 3.7.1.4 Bit 3 XT Busy

This bit reflects the state of the internal XT BUSY flipflop. This bit is set by during a reset and is set when the WD42C22C is selected in XT mode. This bit can NOT be written by the microcontroller.

#### 3.7.1.5 Bit 2 Command / Data

This bit tells the host which type of transfer is expected at the read data and write data ports. C/D = 1 indicates that <u>a</u> command or status transfer is expected and C/D = 0 indicates that a data transfer is expected. This bit is written by the microcontroller

#### 3.7.1.6 Bit 1 Input / Output

This bit tells the host the direction of transfer for the two data ports.  $I/\overline{O} = 1$  indicates an input (read) by the host and  $I/\overline{O} = 0$  indicates an output (write) by the host. This bit is written by the microcontroller.

#### 3.7.1.7 Bit 0 Request

This bit indicates the state of the internal host transfer enable. This bit is active when the buffer manager is transferring data between the RAM and the host. This bit can NOT be written by the microcontroller. This bit is identical to the DRQ in the drive zero status and drive one status registers used in AT mode.

### 3.7.2 Host Drive Configuration (AD7 through AD0 = 2E, Write)

This register is used to write the drive configuration information that is read by the host.

# 3.7.3 Buffer Manager Registers (AD7 through AD0 = 30 Thru 37) Host Buffer Pointer Low (AD7 through AD0 = 30, Read/Write) Host Buffer Pointer High (AD7 through AD0 = 31, Read/Write)

|   | Bit |                |   |      |      |     |   |  |  |  |
|---|-----|----------------|---|------|------|-----|---|--|--|--|
| 7 | 6   | 5              | 4 | 3    | 2    | 1   | 0 |  |  |  |
|   |     | GNIFI<br>POINT |   | BYTE | OF H | OST |   |  |  |  |

|   | Bit |   |       |             |       |       |     |  |  |  |  |  |
|---|-----|---|-------|-------------|-------|-------|-----|--|--|--|--|--|
| 7 | 6   | 5 | 4     | 3           | 2     | 1     | 0   |  |  |  |  |  |
| 0 | –   |   | NIFIC | ANT B<br>ER | ITS ( | OF HO | OST |  |  |  |  |  |

The host buffer pointer low register contains the least significant byte of the host buffer pointer. The host buffer pointer high register contains the seven most significant bits of the host buffer pointer. The host buffer pointer is used as the base address for the internal host buffer counter. The contents of the host buffer pointer registers are transferred to the host buffer pointer counter under the control of the buffer control register.

When the AHBP bit is set in the control register, then the pointer register is transferred to the pointer counter when the transfer counter reaches zero. If the transfer count is already zero, then the transfer occurs immediately. This allows a pending transfer to be queued behind the current transfer. When the pointer is transferred to the counter, the AHBP buffer status bit resets.

## 3.7.4 Host Transfer Count Low (AD7 through AD0 = 32, Read/Write Host Transfer Count High (AD7 through AD0 = 33, Read/Write)

The host transfer count low register contains the least significant byte of the host transfer count. The host transfer count high register contains the most significant bits of the host transfer count. The transfer count controls the number of bytes that are to be transferred on the host interface. The transfer count register is transferred to the internal transfer counter at the same time that the host buffer pointer register is transferred to the host buffer pointer counter. The transfer counter is 12 bits long which gives a maximum transfer

//

12/4/90

count of 4095 bytes.

|     | Bit    |      |      |      |      |     |   |  |  |
|-----|--------|------|------|------|------|-----|---|--|--|
| 7   | 6      | 5    | 4    | 3    | 2    | 1   | 0 |  |  |
| LE/ | AST SI | GNIF | CANT | BYTE | OF H | OST |   |  |  |
| TR/ | ANSFE  | R CO | UNT  |      |      |     |   |  |  |

|   | Bit |   |   |    |                     |   |      |  |  |  |  |
|---|-----|---|---|----|---------------------|---|------|--|--|--|--|
| 7 | 6   | 5 | 4 | 3  | 2                   | 1 | 0    |  |  |  |  |
| 0 | 0   | 0 | 0 | НО | BITS<br>ST T<br>UNT |   | SFER |  |  |  |  |

## 3.7.5 Disk Buffer Pointer Low (AD7 through AD0 = 34, Read/Write) Disk Buffer Pointer High (AD7 through AD0 = 35, Read/Write)

The disk pointer low register contains the least significant byte of the disk buffer pointer. The disk pointer high register contains the seven most significant bits of the disk buffer pointer. The disk buffer pointer is used as the base address for the internal disk buffer counter. The contents of the disk buffer pointer registers are transferred to the disk buffer pointer counter under the control of the buffer control register. When the ADBP bit is set in the control register, then the pointer is transferred to the counter when the drive controller sets DRQI to 1 (bit 1) in the interface status register (38<sub>16</sub>). This allows a pending transfer to be queued behind the current transfer. When the pointer register is transferred to the counter, the ADBP bit in the buffer status resets. If ADBP=0 when the drive controller sets DRQI to 1, then the drive controller stops transferring data to the buffer and discontinues the command until ADBP sets.

| Bit |    |        |                |       |     |    |   |  |
|-----|----|--------|----------------|-------|-----|----|---|--|
| 7   | 6  | 5      | 4              | 3     | 2   | 1  | 0 |  |
|     |    |        | CANT<br>POINTI |       | OF  |    |   |  |
|     |    |        | Bit            |       |     |    |   |  |
| 7   | 6  | 5      | 4              | 3     | 2   | 1  | 0 |  |
| 0   | MO | ST SIG | GNIFIC         | ANT B | YTE | OF |   |  |

### 3.7.6 Microcontroller RAM Access Port (AD7 through AD0 = 36, Read/Write)

This port is used by the local microcontroller to access the buffer RAM. Accesses to this port go through the drive controller's FIFO. These accesses are enabled by the MAC bit in the drive interface control register. The DRWB bit in the buffer manager control register controls the direction of the accesses.

### 3.7.7 Buffer Control Register (AD7 through AD0 = 37, Write)

This register is used to control the buffer manager.

| Bit                  | Bit      |         |
|----------------------|----------|---------|
| 7 6 5 4              | 6        | 7       |
| AT/XT RDCFG RXC AHBP | T RDCFG  | AT/XT F |
| 3 2 1 0              | 2        | 3       |
| HRWB DRWB BDEN ADBP  | B DRWB E | HRWB    |

#### 3.7.7.1 Bit 7 AT / XT Interface Control

This bit, along with HSMB, in the auxilliary buffer cont<u>rol</u> register, controls the host interface type. If AT/XT = 0, then the interface is XT type if HSMB = 0. If AT/XT = 1, then the interface is AT type if HSMB = 0. This bit has no meaning if HSMB = 1. The RESET input and the host soft reset does not affect this bit.

#### 3.7.7.2 Bit 6 Read Configuration

When this bit is set, all buffer address outputs are placed in a medium impedence state with each buffer address pin having a 180  $\mu$ A current source pulldown. The buffer manager should be idle when this mode is enabled. This mode is used to read configuration switch information. The microcontroller should wait 100  $\mu$ sec after setting this bit before reading the configuration registers. This bit resets when RESET is asserted.

#### 3.7.7.3 Bit 5 Reset Transfer Counter

When this bit is set, the internal transfer counter and the host FIFO pointers reset. This bit resets after the transfer counter and FIFO reset.

27-30

12/4/90

#### 27

#### 3.7.7.4 Bit 4 Arm Host Buffer Pointer

Writing a 1 to this bit, sets an internal latch. Writing a 0 to this bit has no effect. When this bit is set, then when the internal transfer counter reaches zero the host buffer pointer is transferred to the internal host buffer counter and the host transfer count is transferred to the internal transfer counter. This bit is reset by the WD42C22C after the host pointer and count registers are transferred. This bit resets when RESET is asserted.

#### 3.7.7.5 Bit 3 Host Read / Write

This bit controls the direction of the host data transfers. It is used internally to control the direction of the FIFO. When HRWB = 0, then the host writes to the WD42C22C. When HRWB = 1, then the host reads from the WD42C22C.

#### 3.7.7.6 Bit 2 Disk Read / Write

This bit controls the direction of the disk or local microcontroller data transfers. It is used internally to control the direction of the disk FIFO. When DRWB = 0, then the disk controller or local microcontroller writes to the buffer RAM. When DRWB = 1, then the disk controller or local microcontroller reads from the buffer RAM. When the microcontroller accesses the buffer RAM, then this bit should be written before the ADBP bit is set.

#### 3.7.7.7 Bit 1 Burst DMA Enable

When BDEN = 1 and HDMA = 1 in the auxilliary buffer control register, then burst DMA transfers are enabled on the host interface.

#### 3.7.7.8 Bit 0 Arm Disk Buffer Pointer

Writing a 1 to this bit, sets an internal latch. Writing a 0 to this bit has no effect. When this bit is set, then the disk buffer pointer is transferred to the internal disk buffer counter when the drive controller sets the BDRQ interrupt. This bit also enables the disk controller to continue to the next sector. This bit is reset by the WD42C22C after the pointer registers have been transferred. When the disk controller port is used by the local microcontroller to access the buffer RAM, then setting this bit resets the disk FIFO pointers and

the next byte read or written by the microcontroller will be at the new address loaded into the disk buffer pointer.

### 3.7.8 Buffer Status Register (AD7 Thru AD0 = 37, Read)

This register reflects the status of the buffer manager logic.

| Bit   |       |      |      |  |  |  |  |  |
|-------|-------|------|------|--|--|--|--|--|
| 7     | 6     | 5    | 4    |  |  |  |  |  |
| AT/XT | RDCFG | RXC  | AHBP |  |  |  |  |  |
| 3     | 2     | 1    | 0    |  |  |  |  |  |
| HRWB  | DRWB  | BDEN | ADBP |  |  |  |  |  |

#### 3.7.8.1 Bit 7 AT / XT Interface Mode

This status bit reflects the state of the  $AT/\overline{XT}$  control bit defined above.

#### 3.7.8.2 Bit 6 Read Configuration

This bit reflects the state of the read configuration control bit defined in the buffer manager control register.

#### 3.7.8.3 Bit 5 Reset Transfer Counter

This bit reflects the state of the RXC control bit defined in the buffer control register.

#### 3.7.8.4 BIT 4 Host Buffer Pointer Armed

This bit reflects the state of the AHBP control bit defined in the buffer control register.

#### 3.7.8.5 Bit 3 Host Read / Write

This bit reflects the state of the HRWB control bit defined in the buffer control register.

#### 3.7.8.6 Bit 2 Disk Read / Write

This bit reflects the state of the DRWB control bit defined in the buffer control register.

**//**/

12/4/90 27-31

#### 3.7.8.7 Bit 1 Burst DMA Enable

This bit reflects the state of the BDEN control bit defined in the buffer control register.

#### 3.7.8.8 Bit 0 Disk Buffer Pointer Armed

This bit reflects the state of the ADBP control bit defined in the buffer control register.

### 3.7.9 AUxilliary Buffer Control Register (AD7 through AD0 = 2F, Write)

This register is used for additional control of the buffer manager and host interface.

|      | Bit  |       |      |
|------|------|-------|------|
| 7    | 6    | 5     | 4    |
| HDMA | HSMB | BCNT  | IDD  |
| 3    | 2    | 1     | 0    |
| DSEL | X    | H16/8 | SCKS |

#### 3.7.9.1 Bit 7 Host DMA

This bit controls the host data transfers to/from the buffer RAM. If HDMA = 1, then the data is transferred to the host via DMA regardless of the host interface selected. If HDMA = 0, the default, then data is transferred via programmed I/O.

#### 3.7.9.2 Bit 6 Host Slave / Master

When HSMB = 0, the default, then the host is a master which drives the WD42C22C in either XT or AT type interface. When HSMB = 1, then the host is a slave device which is controlled by the local microcontroller. The slave device can be addressed in either ALE or indirect mode. The SBIC is an example of a device which can be connected to the WD42C22C. The ALE mode supports up to 32 registers in the slave device. Data transfers occur via WD-BUS mode if HDMA = 1 and is an 8-bit transfer if H16/8 = 0 and a 16-bit transfer if H16/8 = 1. This bit resets upon power-up but not affected by RESET.

#### 3.7.9.3 Bit 5 Burst Continuous

This bit, along with the HDMA bit, and the BDEN bit in the buffer control register control the bursting of data during DMA transfers. If BCNT = 1, HDMA = 1, and BDEN = 1, then the WD42C22C DMAs data continuously as long as the FIFOs can keep up. If BCNT = 0, HDMA = 1, and BDEN = 1, then the WD42C22C DMAs data in 8-byte or 16-byte maximum length bursts, for 8 and 16 bit host data bus width, respectively.

#### 3.7.9.4 Bit 4 Intelligent Drive Decode

When IDD = 1, then the controller is assumed to be on an intelligent drive. The HD0-15, INTRQ, and DREQ/IOCS16 outputs are always tristated if the drive is not selected. If IDD = 0, the default, then the outputs are controlled normally. This bit resets upon power up but not affected by RESET.

#### 3.7.9.5 Bit 3 Drive Select

This bit is used when IDD = 1 to control drive selection. If  $AT/\overline{XT}$  =1, then the drive is considered selected when SDH register bit 4 equals DSEL. If  $AT/\overline{XT}$  = 0, then the drive is considered selected if DSEL = 1 and not selected if DSEL = 0. This bit resets upon power-up but not affected by RESET.

#### 3.7.9.6 Bit 1 Host 16 / 8 Bit

This bit controls the width of the data transfers on the host side. If H16/8 = 0, then the host data transfers are 8-bit. If H16/8 = 1, the host data transfers are 16-bit. This bit resets upon power up but not affected by RESET.

#### 3.7.9.7 Bit 0 Synchronous Clock Switch

This bit is used to control the clocking of the drive controller so that ESDI drives can be changed or data rates can be changed without the need for external clock deglitching. When SCKS =1, the default, then the WD42C22C synchronously switches the drive controller to the internal buffer clock (BCLK). When SCKS = 0, the WD42C22C switches the drive controller back to WCLK. The switch occurs only if both clocks are present. The CKSRC status bit defined below indicates whether or not the switch occured. When RESET

27

is asserted, the buffer clock clocks the drive controller during the reset and SCKS is set. The microcontroller must switch the clock source to the WCLK input prior to issuing any commands to the drive controller.

### 3.7.10 Auxilliary Buffer Status Register (AD7 through AD0 = 2F, READ)

This register gives additional status of the buffer manager and host interface.

|      | Bit  |       |      |
|------|------|-------|------|
| 7    | 6    | 5     | 4    |
| HDMA | HSMB | BCNT  | IDD  |
| 3    | 2    | 1     | 0    |
| DSEL | CKSC | H16/8 | SCKS |

#### 3.7.10.1 Bit 7 Host DMA

This bit reflects the state of the HDMA control bit defined in the auxilliary buffer control register.

#### 3.7.10.2 Bit 6 Host Slave / Master

This bit reflects the state of the HSMB control bit defined in the auxilliary buffer control register.

#### 3.7.10.3 Bit 5 Burst Continuous

This bit reflects the state of the BCNT control bit defined in the auxilliary buffer control register.

#### 3.7.10.4 Bit 4 Intelligent Drive Decode

This bit reflects the state of the IDD control bit defined in the auxilliary buffer control register.

#### 3.7.10.5 Bit 3 Drive Select

This bit reflects the state of the DSEL control bit defined in the auxilliary buffer control register.

#### 3.7.10.6 Bit 2 Clock Source

This bit indicates the source of the drive controller clock. If CKSRC = 1 and SCKS = 1, then the drive controller is being clocked by the buffer clock (BCLK). If CKSRC = 0 and SCKS = 0, then the drive controller is clocked by WCLK. If CKSRC = 1 and SCKS = 0 or CKSRC = 0 and SCKS = 1, then the clock source is undefined. CKSRC should not be checked until at least 10 clock periods after the SCKS has been written. The slower of BCLK and WCLK should be used in determining this delay.

#### 3.7.10.7 Bit 1 Host 16 / 8

This bit reflects the state of the H16/8 control bit defined in the auxilliary buffer control register.

#### 3.7.10.8 Bit 0 Synchronous Clock Switch

This bit reflects the state of the SCKS control bit defined in the auxilliary buffer control register.

### 3.7.11 Interface Status Register (AD7 Through AD0 = 38, READ)

This register is used to indicate the status of the WD42C22C. The bits are defined as follows:

|      | Bit  |      |      |
|------|------|------|------|
| 7    | 6    | 5    | 4    |
| MINT | DCGI | RSTI | FEI  |
| 3    | 2    | 1    | 0    |
| DCI  | HPRI | DRQI | CWSI |

#### 3.7.11.1 Bit 7 Microcontroller Interrupt

This bit is high if the MCINT output pin is asserted. MCINT is the logical OR of seven sources:

- · A host SDH register write
- · A host soft reset
- · A FIFO error
- · The disk controller interrupt signal
- The host transfer count interrupt flip-flop
- The disk controller BDRQ signal
- The command write/select interrupt flip-flop.

//

12/4/90 27-33

If any of the bits 6 through 0 are set, then the MCINT bit is high.

#### 3.7.11.2 Bit 6 Drive Change Interrupt

This bit sets when the host writes a new value to the SDH register bit 4 when AT mode is selected.

#### 3.7.11.3 Bit 5 Soft Reset Interrupt

This bit sets if the host initiates a soft reset. This bit resets by writing the proper bit in the interface control register.

#### 3.7.11.4 Bit 4 FIFO Error Interrupt

This bit sets if a FIFO overrun or underrun condition occurs during host or disk transfers. It resets by writing the proper bit in the interface control register.

#### 3.7.11.5 Bit 3 Disk Controller Interrupt

This bit reflects the state of the disk controller interrupt signal. This interrupt occurs at the end of a command. This bit resets either when the disk controller status (port 27<sub>16</sub>) is read or when the disk controller command (port 27<sub>16</sub>) register is written.

### 3.7.11.6 Bit 2 Host Pointer Ready Interrupt

This bit reflects the state of the host transfer count interrupt flip-flop. This interrupt sets when the host transfer counter reaches zero and the FIFO is empty if the host pointer is not armed. It is also set when the host pointer pipeline register is loaded into the host pointer counter. It resets by writing the proper bit in the interface control register.

#### 3.7.11.7 Bit 1 Disk BDRQ Interrupt

This bit reflects the state of the disk controller BDRQ signal. It sets when the disk controller starts a transfer between the disk controller and the sector buffer. It resets by writing the proper bit in the interface control register. If ADBP = 0 (bit 0

in the buffer control register,  $37_{16}$ ) when this bit first goes from 0 to 1, then DRQI and MCINT is not reset until after the microcontroller writes ADBP = 1.

### 3.7.11.8 Bit 0 Command Write / Select / Slave Interrupt

This bit informs the local microcontroller that a command has been written if the WD42C22C is in AT mode, that the WD42C22C has been

selected if it is in XT mode, or that the slave host device has issued an interrupt if in slave host mode. (Asserts INTRQ. A slave interrupt only triggers on rising edge of INTRQ.) This bit resets by writing the proper bit in the interface control register.

### 3.7.12 Interface Control Register (AD7 through AD0 = 38, Write)

This register is used to control various parts of the WD42C22C. The bits are defined as follows:

|      | Bit  |      |      |  |  |  |  |  |  |
|------|------|------|------|--|--|--|--|--|--|
| 7    | 6    | 5    | 4    |  |  |  |  |  |  |
| SIRQ | RDCI | RSRI | RFEI |  |  |  |  |  |  |
| 3    | 2    | 1    | 0    |  |  |  |  |  |  |
| RBSY | RHRI | RDQI | RCWS |  |  |  |  |  |  |

#### 3.7.12.1 Bit 7 Set Interrupt

Writing a 1 to this bit generates a host interrupt if interrupts are enabled.

### 3.7.12.2 Bit 6 Reset Drive Change Interrupt

Writing a 1 to this bit resets the host SDH write interrupt flip-flop.

### 3.7.12.3 Bit 5 Reset Soft Reset Interrupt

Writing a 1 to this bit resets the soft reset interrupt flip-flop. In AT mode, the microcontroller must wait for the RST bit (2) in the FDR register (3F<sub>16</sub>) to be

27

reset by the host before this interrupt can be reset.

### 3.7.12.4 Bit 4 Reset FIFO Error Interrupt

Writing a 1 to this bit resets the FIFO error interrupt flip-flop.

#### 3.7.12.5 Bit 3 Reset Busy

Writing a 1 to this bit resets the BSY status bit in the hardware status register if XT mode is selected or it resets the ABSY status bit in the host status register if AT mode is selected. In AT mode, this bit should only be set at the very end of a command after the last DRQ is asserted to the host. Internal logic handles ABSY during buffer transfers to the host.

### 3.7.12.6 Bit 2 Reset Host Pointer Ready Interrupt

Writing a 1 to this bit resets the host pointer ready interrupt flip-flop.

#### 3.7.12.7 Bit 1 Reset Disk BDRQ Interrupt

Writing a 1 to this bit resets the disk BDRQ interrupt flip-flop.

### 3.7.12.8 Bit 0 Reset Command Write / Select / Slave Interrupt

Writing a 1 to this bit resets the command write/select/slave interrupt flip-flop.

#### 3.7.13 Configuration Status Registers (Low: AD7 through AD0 = 39, Read High: AD7 through AD0 = 3A, Read)

The configuration status registers are used to read the configuration jumpers on buffer address pins. When in read configuration mode, the buffer address lines have 300  $\mu$ A current source pulldowns enabled. If there is no external pullup resistor on the buffer address line, then the state of the line is read as a 0. If a 13K external pullup resistor is connected to a buffer address line, then the state of the line is read as a 1. The

configuration registers should not be read until 100 µsec after enabling read configuration mode, to allow the buffer address line voltages to reach their proper value. Register contents are undefined if not in read configuration mode.

| Configuration status low Bit |        |        |        |       |   |   |   |  |  |
|------------------------------|--------|--------|--------|-------|---|---|---|--|--|
|                              |        |        |        |       |   |   |   |  |  |
|                              |        | ВА     | 7 THR  | U BA0 |   |   |   |  |  |
| Confi                        | gurati | ion st | atus I | nigh  |   |   |   |  |  |
|                              |        |        | Bit    |       |   |   |   |  |  |
| 7                            | 6      | 5      | 4      | 3     | 2 | 1 | 0 |  |  |
| 0                            | BA1    | 4 THF  | RU BA  | 3     |   |   |   |  |  |

### 3.7.14 Drive Interface Status (AD7 through AD0 = 3B, Read)

This register gives status information for the drive controller. It is coded as follows:

| Bit |      |    |     |     |     |      |     |  |
|-----|------|----|-----|-----|-----|------|-----|--|
| 7   | 6    | 5  | 4   | 3   | 2   | 1    | 0   |  |
| RDC | DRDY | WF | HDS | MAC | DRO | IPOL | DSN |  |

#### 3.7.14.1 Bit 7 Reset Drive Controller

This bit reflects the state of the reset drive controller control bit defined in the drive interface control register.

#### 3.7.14.2 Bit 6 Drive Ready

This bit is set if the DRDY input is asserted by the drive. It can always be read by the local microcontroller regardless of the state of disk controller busy.

#### 3.7.14.3 Bit 5 Write Fault

This bit is set if the  $\overline{WF}$  input is asserted by the drive. It is always valid.

**//** 

#### 3.7.14.4 Bit 4 Host Drive Select

This bit reflects the state of bit 4 of register 46<sub>16</sub>, the host copy of the SDH register. It is used by the host in AT mode as a drive select. If HDS = 0, then drive 1 is selected. If HDS = 1, then drive 2 is selected. This bit is always accessable to the microcontroller regardless of the state of ABSY.

#### 3.7.14.5 Bit 3 Microcontroller Access Control

This bit reflects the state of the microcontroller access control bit defined in the drive interface control register.

#### 3.7.14.6 Bit 2 Disable Reset Output

This bit reflects the state of the disable reset output control bit defined in the drive interface control register.

#### 3.7.14.7 Bit 1 Input Polarity

This bit reflects the state of the input polarity control bit defined in the drive interface control register.

#### 3.7.14.8 Bit 0 Disable Sector Number

This bit reflects the state of the disable sector number control bit defined in the drive interface control register.

### 3.7.15 Drive Interface Control (AD7 through AD0 = 3B, Write)

This register is used to control the drive controller. It is coded as follows:

| Bit |   |   |   |     |     |      |     |
|-----|---|---|---|-----|-----|------|-----|
| 7   | 6 | 5 | 4 | 3   | 2   | 1    | 0   |
| RDC | Х | X | X | MAC | DRQ | IPOL | DSN |

#### 3.7.15.1 Bit 7 Reset Drive Controller

When this bit is asserted, then the drive controller subsection of the WD42C22C resets. It is held reset as long as the bit is asserted. This bit is reset when RESET is asserted.

#### 3.7.15.2 Bit 3 Microcontroller Access Control

When this bit is set, the microcontroller is tied to the buffer RAM through the disk controller's port. The microcontroller can then read or write the buffer by reading from or writing to the RAM access port (36<sub>16</sub>). The DRWB bit in the buffer manager control port should be set to the proper state before this bit is set. When MAC = 1, then the disk controller task file (registers 21<sub>16</sub> through 27<sub>16</sub>) cannot be accessed by the microcontroller. If the microcontroller writes to these registers when MAC = 1, then the disk controller may not act properly. This bit resets when RESET is asserted. The proper sequence for the microcontroller to read/write the RAM is defined under the buffer manager description.

#### 3.7.15.3 Bit 2 Disable Reset Output

When this bit is set, all host initiated soft resets are disabled. Instead of the RESET line being asserted on soft reset, only the MCINT line is asserted. It is the responsibility of the local microcontroller to properly reset the board hardware when this bit is set. This bit resets only during power-up.

#### 3.7.15.4 Bit 1 Input Polarity

This bit is used to control the polarity of the INDEX, SCT, WF, and DRDY inputs. If IPOL= 0, the default, then the inputs are active low. If IPOL = 1, then the inputs are active high. In soft sector MFM and RLL modes, DRUN is always active high regardless of the state of IPOL.

#### 3.7.15.5 Bit 0 Disable Sector Number

When this bit is set, then the drive controller does not compare the sector number coming from the drive with the desired sector number when reads or writes are performed. The drive controller instead writes the sector number coming from the drive into the sector number register in the drive controller task file. At the end of each sector, just prior to issuing DRQI or DCI, the drive controller always writes the sector number to the alternate sector number register. This bit resets when RESET is asserted.

When the disk controller interrupts the microcontroller, this register holds the sector number of the sector just read or written. It is always updated just prior to the disk BDRQ interrupt (DRQI) or the disk controller interrupt (DCI). It is initialized to FF<sub>16</sub> at the start of every command. It is written regardless of the state of the DSN bit described above.

|   | Bit           |   |        |      |     |      |   |
|---|---------------|---|--------|------|-----|------|---|
| 7 | 6             | 5 | 4      | 3    | 2   | 1    | 0 |
|   | MBER<br>ITTEN |   | AST SE | CTOR | REA | D OF | 7 |

#### 3.8 AT Interface Ports

## 3.8.1 AT Control Register (AD7 through AD0 = 2A, Read/Write)

This register controls the new auto-DRQ option for write, write long, and format commands.

|   |   |   | Bit |   |     |     |      |
|---|---|---|-----|---|-----|-----|------|
| 7 | 6 | 5 | 4   | 3 | 2   | 1   | 0    |
| 0 | 0 | 0 | 0   | 0 | 0 A | DQ7 | ADRQ |

## 3.8.1.1 Bits 7 through 2 Reserved

Set to 0.

#### 3.8.1.2 Bit 1 Auto-DRQ 7 Byte ECC

When ADRQ = 1 and ADQ = 1, then 7 ECC bytes are transferred to/from the host on a read long or write long command. When ADRQ = 1 and ADQ7 = 0, then 4 ECC bytes are transferred to/from the host on a read long or write long command. When ADRQ = 0, then the ECC7 bit in the fixed disk register (3F<sub>16</sub>) controls the number of ECC bytes transferred on read long and write long commands.

#### 3.8.1.3 Bit 0 Auto-DRQ Enable

When ADRQ = 1 in AT mode, then the WD42C22C automatically sets up the first data transfer from the host for write, write long, and format commands. When ADRQ = 0, the local microcontroller must set up all data transfers to/from the host for all commands.

## 3.8.2 Drive Zero Status (AD7 through AD0 = 3D, Read/Write)

In PC/AT mode, bits 6, 5, 4, 2, and 0 of the host status register are controlled by the local microcontroller. Bits 6, 5, 4, 2, and 0 of the host status register are set to the values of bits 6, 5, 4, 2, and 0, respectively, of this register if bit 4 of the AT task file copy SDH register (port 46 for microcontroller, port 6 for host) is 0. The other bits of the host status are not affected by this register.

### 3.8.3 Drive One Status (AD7 through AD0 = 3E, Read/Write)

In AT mode, bits 6, 5, 4, 2, and bit 0 of the host status register are controlled by the local microcontroller. Bits 6, 5, 4, 2, and 0 of the host status register is set to the values of bits 6, 5, 4, 2, and 0, respectively, of this register if bit 4 of the AT task file copy SDH register (port 46 for microcontroller, port 6 for host) is 1. The other bits of the host status are not affected by this register.

## 3.8.4 Fixed Disk Register (AD7 through AD0 = 3F, Read)

This register contains the fixed disk register data written by the host.

|   |   |   | В | lit   |       |      |   |
|---|---|---|---|-------|-------|------|---|
| 7 | 6 | 5 | 4 | 3     | 2     | 1    | 0 |
| 0 | 0 | 0 | 0 | HS3EN | I RS1 | ΓĪĒΝ | 0 |

27

## 3.8.5 Digital Input Register (AD7 through AD0 = 3F, Write)

Bit 5 of this register is written by the local microcontroller and read by the host if the fixed disk register bit 3 is zero. This bit is inverted when this register is read by the host. If HS3EN is one, then bit 5 of this register comes from SDH register bit 3.

|      |               |     | Bit |   |   |     |     |
|------|---------------|-----|-----|---|---|-----|-----|
| 7    | 6             | 5   | 4   | 3 | 2 | 1   | 0   |
| ECCM | ECC7/<br>DDRQ | RWC | X   | X | X | DS1 | DS0 |

#### 3.8.5.1 Bit 7 ECC Mode

In PC/AT mode, ECCMOD = 1 indicates that the data transferred to the host includes ECC. The ECC is transferred in <u>bytes rather</u> than in words. This bit is reset when RESET is asserted. This bit should not be set in XT or slave host modes.

#### 3.8.5.2 Bit 6 ECC 7 Bytes/ Disable BDRQ

When ECCM = 1, then this bit determines the number of ECC bytes transferred to the host. If ECC7 = 1, then 7 bytes are transferred. Otherwise, 4 bytes are transferred. If ECCM = 0, then this bit controls whether or not the drive controller issues BDRQ interrupts. If DDRQ = 0, then the drive controller issues BDRQ interrupts. If DDRQ = 1, then the drive controller does not issue BDRQ interrupts. It should be noted that when BDRQ occurs, the buffer manager loads the disk pointer from its pipeline register and when no BDRQ occurs then the disk pointer keeps incrementing from one sector to the next. This bit resets when RESET is asserted.

#### 3.8.5.3 Bit 5 Reduce Write Current

This bit is set by the <u>micro</u>controller and indicates the state of the RWC signal going to the drive.

#### 3.8.5.4 Bit 1 Drive Select 1

This bit controls the state of the DS1 output pin. When DS1 = 0, then the DS1 output is tristated and when DS1 = 1 the DS1 output is low. This bit is reset when RESET is asserted.

#### 3.8.5.5 Bit 0 Drive Select 0

This bit controls the state of the  $\overline{DSO}$  output pin. When DS0 = 0, then the  $\overline{DSO}$  output is tristated and when DS0 = 1 the the DS0 output is low. This bit is reset when RESET is asserted.

# 3.8.6 AT Task File Copy (AD7 through AD0 = 40 Thru 47, Read/Write)

These registers are a copy of the disk controller task file. They are loaded by the host prior to the start of a command. The local microcontroller must read the command and interpret it and then copy the appropriate parameters from this task file copy to the actual drive controller task file (20<sub>16</sub>-27<sub>16</sub>). At the end of the command, the local microcontroller must update this task file copy before asserting INTRQ and resetting ABSY. The local microcontroller can only access these registers when ABSY=1.

## 27

## 4.0 BUFFER MANAGER ORGANIZATION

The buffer manager can control multiple sector buffers totalling up to 32 Kbytes. The buffer interface requires static RAMs. The sector buffers can be any size up to 2055 bytes, including ECC, and can be located at any byte boundary. The buffer manager has two address counters, one for the host interface and one for the disk data buffer. Both counters can access the SRAM simultaneously. The buffer manager handles the arbitration between the host interface and the drive controller. There is a FIFO in the host data interface that allows a sustained bandwidth of 4 Mwords/sec (8 Mbytes/sec) for 16-bit wide transfers and 8 Mbytes/sec for 8-bit wide transfers. The buffer manager can sustain a RAM bandwidth of 10 Mbytes/sec.

When the local microcontroller wants to access the buffer RAM, it has to use the disk buffer manager logic. It first loads the desired starting address into the disk buffer pointer. The proper buffer manager control bits are then set to enable the local microcontroller access to the buffer. When the local microcontroller accesses the special RAM access port (register 3616), the data is read/written through the disk controller's FIFO port to the buffer. The RAM can only be accessed sequentially from the starting address and only in one direction as set by the DRWB control bit in the buffer control register.

Both address counters are pipelined. There are registers that can be loaded with the starting address of the next sector buffer while the current buffer is transferring. This allows noncontiguous buffers to be chained without any loss of RAM bandwidth between sectors.

**//** 

## 4.1 ACCESSING BUFFER RAM FROM THE MICRO-CONTROLLER

The microcontroller can read and write the buffer RAM. To read the buffer RAM the procedure is:

- Set DRWB = 1 (bit 2) in the buffer manager control Register (37<sub>16</sub>).
- Set MAC = 1 (bit 3) in the disk controller control register (3B<sub>16</sub>).
- Load the starting address of the data being accessed into the disk buffer pointer registers (34 & 35<sub>16</sub>).
- 4. Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).

The buffer manager begins reading data out of the RAM starting at the address specified in the disk pointer register and placing it into the FIFO. As the microcontroller reads from the RAM access port (3616), sequential bytes from the buffer are transferred from the FIFO to the microcontroller.

The procedure to write to the buffer RAM is:

- Set DRWB = 0 (bit 2) in the buffer manager control register (37<sub>16</sub>).
- 2. Set MAC = 1 (bit 3) in the disk controller control register ( $3B_{16}$ ).
- Load the starting address of the data being accessed into the disk buffer pointer registers (34 & 35<sub>16</sub>).
- 4. Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).

As the microcontroller writes data to the RAM access port (36<sub>16</sub>), the buffer manager transfers the bytes to sequential locations in the buffer RAM starting at the address specified in the disk pointer register.

#### NOTE

DRWB should not be changed while MAC = 1.

## 4.2 STARTING HOST TRANSFERS TO/FROM BUFFER RAM

Host transfers can be performed in several modes. The modes available and the setup required to establish each mode are as follows:

| HDMA       | BDEN                       | BCNT        | H16/8- |  |  |  |  |  |
|------------|----------------------------|-------------|--------|--|--|--|--|--|
| 1          | 0 ·                        | X           | 0      |  |  |  |  |  |
| 8-bit wide | 8-bit wide single byte DMA |             |        |  |  |  |  |  |
| 1          | 0                          | X           | 1      |  |  |  |  |  |
| 16-bit wid | le single word             | AMD I       |        |  |  |  |  |  |
| 1          | 1                          | 0           | 0      |  |  |  |  |  |
| 8-bit wide | , 8-byte burs              | t DMA       |        |  |  |  |  |  |
| 1          | 1                          | 0           | 1      |  |  |  |  |  |
| 16-bit wid | e, 16-byte bu              | irst DMA    |        |  |  |  |  |  |
| 1          | 1                          | 1           | 0      |  |  |  |  |  |
| 8-bit wide | , continuous               | burst DMA   |        |  |  |  |  |  |
| 1          | 1                          | 1           | 1      |  |  |  |  |  |
| 16-bit wid | e, continuous              | s burst DMA |        |  |  |  |  |  |
| 0          | X                          | ×           | 0      |  |  |  |  |  |
| 8-bit wide | PIO                        |             |        |  |  |  |  |  |
| 0          | X                          | X           | 1      |  |  |  |  |  |
| 16-bit wid | e PIO                      |             |        |  |  |  |  |  |

Bits HDMA (bit 7), BCNT(bit 5), and  $H16\overline{/8}$  (bit 1) are in the auxilliary buffer manager control register (2F<sub>16</sub>) and bit BDEN (bit 1) is in the buffer manager control register (37<sub>16</sub>). All of these modes are available in both the XT and AT host configurations. All of the DMA modes are available in the slave host configuration.

To perform a Host read data transfer the following sequence should be followed.

- Set up the appropriate transfer mode as described above.
- 2. Set HRWB = 1 (bit 3) in the buffer control register (37<sub>16</sub>).
- Load the starting address of the desired sector into the host pointer registers (30<sub>16</sub> & 31<sub>16</sub>). Load the number of bytes into the host transfer count registers (32<sub>16</sub> & 33<sub>16</sub>).
- Set AHBP = 1 (bit 4) in the buffer manager control register (37<sub>16</sub>). Hardware automatically sets DRQ (bit 3) and resets ABSY (bit 7) in the host status register if AT mode and sets REQ (bit 0) in the hardware status

- register if XT mode. If DMA transfers are enabled, then the hardware automatically starts the DMA handshake when AHBP is set by the micro-controller.
- 5. Wait for HPRI = 1 (bit 2) in the interface status register (38<sub>16</sub>). MCINT is asserted.
- Set RHRI = 1 (bit 2) in the interface control register (38<sub>16</sub>) to reset the interrupt. If chaining and still more sectors then go to 3.
- 7. Wait for HPRI = 1 (bit 2) in the interface status register (38<sub>16</sub>). MCINT is be asserted.
- Set RHRI = 1 (bit 2) in the interface control register (38<sub>16</sub>) to reset the interrupt. If still more sectors, then go to 3.
- Set RBSY = 1 (bit 3) in the interface control register when the entire command sequence is complete. This resets the ABSY and XBSY host status bits. They stay reset until the next command is issued by the host.

To perform a host write data transfer, the following sequence should be followed.

- Set up the appropriate transfer mode as described above.
- 2. Set HRWB = 0 (bit 3) in the buffer control register (37<sub>16</sub>).
- Load the starting address of the desired sector into the host pointer registers (30<sub>16</sub> & 31<sub>16</sub>). Load the number of bytes into the host transfer count registers (32<sub>16</sub> & 33<sub>16</sub>)
- 4. Set AHBP = 1 (bit 4) in the buffer manager control register (37<sub>16</sub>). Hardware automatically sets DRQ (bit 3) and resets ABSY (bit 7) in the host status register if AT mode and set REQ (bit 0) in the hardware status register if XT mode. If DMA transfers are enabled, then the hardware automatically starts the DMA handshake when AHBP is set by the micro-controller.
- 5. Wait for HPRI = 1 (bit 2) in the interface status register (38<sub>16</sub>). MCINT is asserted.
- Set RHRI = 1 (bit 2) in the interface control register (38<sub>16</sub>) to reset the interrupt. If chaining and still more sectors then go to 3.

- Wait for second HPRI = 1 (bit 2) in the interface status register (38<sub>16</sub>). MCINT is asserted.
- Set RHRI = 1 (bit 2) in the interface control register (38<sub>16</sub>) to reset the interrupt. If still more sectors then go to 3.
- Set RBSY = 1 (bit 3) in the interface control register when the entire command sequence is complete. This resets the ABSY and XBSY host status bits. They stay reset until the next command is issued by the host.

#### 4.3 CONTROLLER COMMANDS

The WD42C22C Winchester command set contains twelve commands. Four commands (read sector, write sector, format, and set parameter) are directly executed through the command register. The remaining commands are not directly available to the host. These commands may be executed by the local microcontroller transparently to the host. Table 12 lists the commands and command codes.

| COMMAND                    | 7  | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----------------------------|----|------|----|---|---|---|---|---|
| Read Sector                | 0  | 0    | 1  | 0 | 0 | М | L | Т |
| Read Next Data             | 0  | 1    | 1  | 0 | 0 | 0 | L | 1 |
| Write Sector               | 0  | 0    | 1  | 1 | Χ | М | L | Т |
| Write ID                   | 1  | 0    | 1  | 1 | F | 0 | Α | Т |
| Scan ID                    | 0  | 1    | 0  | 0 | 0 | 0 | 0 | Т |
| Format Track               | 0  | 1    | 0  | 1 | 0 | 0 | W | 1 |
| Format Single Sector       | 1  | 1    | 0  | 1 | 0 | 0 | W | 1 |
| Compute Correction         | 0  | 0    | 0  | 0 | 1 | Ρ | 0 | 0 |
| Set Parameter              | Ζ  | 0    | 0  | R | 0 | Ε | Н | S |
| Load Parameter Block       | 1  | 0    | 0  | 0 | 1 | D | K | U |
| Sleep                      | 1  | 0    | 0  | 1 | 1 | 0 | 0 | 0 |
| Dump                       | 1  | 0    | 1  | 0 | 1 | В | L | 1 |
| Mnemonic definitions for T | ab | le 1 | 2: |   |   |   |   |   |

TABLE 12. COMMAND AND COMMAND CODES

- M=0 Single sector read or write. Sector count is ignored.
  - M=1 Multiple sector read or write. Used for 1:1 interleave.
- L=0 Normal mode, selected ECC or CRC functions performed.

- L=1 Sector extended by 4 or 7 bytes (depends on set parameter command.

  No ECC generated or checked.
- T=0 Enable retries.
- T=1 Disable retries.
- X=0 Write sector specified in sector number register.
  - X=1 Write sector specified in first byte of the sector buffer.
- F=0 Write new ID immediately after current ID
  - F=1 Write new ID offset from current ID.
- A=0 Do not pulse AME when writing new ID.
  - A=1 Pulse AME when writing new ID.
- W=0 Write gate stays asserted for entire track or sector.
  - W=1 Write gate deasserted over all gaps during format.
- P=0 Transfer syndrome bytes to buffer and calculate error pattern bytes and transfer them to the buffer.
- P=1 Transfer syndrome bytes to the buffer but do not calculate error pattern bytes.
- Z=0 MFM or RLL mode.
- Z=1 NRZ mode. Mode used for ESDI drive interface.
- R=0 Disable relocation ID searches.
- R=1 Enable relocation ID searches.
- E=0 Sector extension for read long/write long 4 bytes. ECC generator/checker is 4 bytes.
  - E=1 Sector extension for read long/write long 7 bytes. ECC generator/checker is 7 bytes.
- H=0 SDH register programmed for 3 head select bits.
- H=1 SDH register programmed for 4 head select bits.
- S=0 Error correction span 5 bits with 4 byte ECC or 11 bits with 7 byte ECC.
  - S=1 Error correction span 11 bits with 4 byte ECC or 22 bits with 7 byte ECC.
- D=0 Select soft sector drive interface. Default after master reset.
- D=1 Select hard sector drive interface. In this mode, DRUN becomes a sector pulse input.



27-41

| MODE            |   | MODE<br>CONTROL |   | OPTIONS |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-----------------|---|-----------------|---|---------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|                 | Z | D               | K | М       | Т | L | X | Α | F | R | S | E | Н | Р | U | W | ı | В |
| RLL soft sector | ? | 0               | 0 | ×       | Х | х | х | х | х | Х | х | * | х | х | x | - |   |   |
| RLL hard sector | ? | 1               | 0 | Х       | Х | Х | х | Х | х | Х | x | * | Х | Х | x | х | х | x |
| MFM soft sector | 0 | 0               | 1 | х       | х | х | х | х | Х | х | X | х | X | X | X |   | - | Ť |
| MFM hard sector | 0 | 1               | 1 | x       | Х | Х | X | X | X | x | X | x | X | X | x | x | x | X |
| NRZ soft sector | 1 | 0               | 1 | х       | x | Х | X | х | Х | x | X | x | x | X | X |   |   | _ |
| NRZ hard sector | 1 | 1               | 1 | x       | x | х | X | X | x | x | X | X | X | × | X | x | x | x |

- ? Don't care, could be 0 or 1.
- x These options are supported.
- \* These options have no effect.

## **TABLE 13. OPTION SUMMARY TABLE**

- K=0 RLL data interface. Selection of this option disables the NRZ option. Defaults to this setting after master reset.
- K=1 Data interface is either MFM or NRZ.
- U=0 Use the standard sector sizes defined under the SDH register description.
- U=1 Select user defined sector size. The desired sector size is put into the cylinder registers prior to issuing a load parameter block command. The auxilliary set parameter command transfers the desired sector size from the cylinder registers to an internal sector size register.
- l=0 Dump two fields per sector. Dump 5 ID bytes and the number of data bytes set by the sector size.
  - i=1 Dump only one field per sector. The size of the field is set by the sector size and type of field (ID versus data) is controlled by where RG is asserted.
- B=0 FE sync byte and zero preset CRC.
- B=1 A1 sync byte and ones preset CRC.

Table 13 summarizes the data formats and options supported by these formats.

#### 4.4 COMMAND DESCRIPTIONS

#### 4.4.1 Read Sector

If M=0, then the sector specified in sector number register is read. If M=1, then multiple records are read. If the sector count register = 0, then 256 sectors are read at the desired track.

If T=0, then ID searches are retried for 10 index pulses. DAM not found errors are not retried. There are no retries for CRC/ECC errors. If T=1, ID searches are retried for two index pulses.

If L=0, then normal CRC or ECC read commands are performed. If L=1, then the CRC or ECC check bytes are not computed but instead the CRC or ECC check bytes are loaded into the buffer immediately after the data field. The external sector buffer must be long enough to hold the additional 4 or 7 bytes. If ECC and retry modes have been selected and a data field error occurs there are no attempts to correct the data.

A bad block mark in the ID field sets the error bit and the data field is not read. If the R option in the set parameter command is set then the controller searches immediately after the normal ID field for a special ID field containing mapping information and a special "Relocation ID" flag bit. The RIDF bit in the error register sets if this special ID field is found. If a bad block mark is found in an ID field then the command terminates immediately

even if more sectors remain to be read. The task file contents when a bad block bit is detected and the R option is used is as follows:

| REGISTER | MEANING                                                        |
|----------|----------------------------------------------------------------|
| 22       | Sector number of sector with                                   |
| 23       | bad block bit set Sector umber where sector has been relocated |
| 24       | LSB of cylinder number                                         |
|          | where sector has been reloc-<br>ated                           |
| 25       | MS bits of Cylinder where sector has been relocated            |
| 26       | Head number of relocated sector                                |

If DSN = 1 (bit 0) in the drive interface control register ( $3B_{16}$ ) than the sector number is not compared when ID searches are performed. The WD42C22A reads the sector as long as the cylinder and head numbers match the desired values. This allows an interleaved track to be read into the buffer in one revolution.

#### **Command Flow:**

- · MICRO:
- Set DRWB = 0 (bit 2) in the buffer manager control register (37<sub>16</sub>).
- Load the starting address of the first sector into the disk buffer pointer registers (34<sub>16</sub> & 35<sub>16</sub>).
- Set ECCM = 0 (bit 7) and DDRQ = 1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC=1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI, if desired.
- 4. Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- 5. Set MAC = 0 in the drive interface control register.
- 6. Issue read command to WD42C22C.
- WD42C22C: 7. Write FF to alternate sector number register (3C<sub>16</sub>).
   Abort if drive not ready or write fault.
  - 8. (If DRQI is enabled)
    Activate BDRQ signal to

buffer manager and DRQI to microcontroller. Wait for BRDY signal indicating transfer of buffer pointer.

- Load starting address of next sector buffer into disk buffer pointer register. Set ADBP=1 in buffer manager control register if more sectors remaining. Set RDQI (bit 1) in the interface control register
- (38<sub>16</sub>).

   WD42C22C: 9. Search for head, cylinder, sector number, and sector size code.
  - When the proper sector ID is found, read sector data and place in buffer.
  - Write sector number to alternate sector number register.
     If M = 0, then go to 10.
  - Decrement sector count, increment sector number. If
     M = 1, and sector count = 0
     then go to 13 else go to step
     8
  - Set DCI (bit 3) in the interface status register (38<sub>16</sub>).
     MCINT asserted.
- MICRO: 14. Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

## Error Flags:

- Drive not ready and aborted command set if drive not ready.
- Write fault and aborted command set if WF pin activated.
- ID not found set if ID field not found or if ID field matches, but CRC check fails, and after retry procedure.
- Bad block set if attempt was made to read a sector with bad block mark.
- Relocation ID found if R option enabled and relocation ID detected.
- Data CRC/ECC set if data field CRC or ECC check fails. No attempt is made to correct ECC errors.
- Data AM not found in set if data address mark not found.

//

#### 4.4.2 Read Next Data

The read next data command finds the next data field and places it in a buffer. If the WD42C22C detects that the drive number changed since the last read command, then an auto-scan ID is performed and step pulses are issued to update the present cylinder position.

All searches for a data field are retried for two index pulses, but if a data ECC error is detected there are no retries. If after reading the correct ID field, the data address mark is not found a DAM error is set.

The L flag controls the ECC check bytes. If L=0, then the data field is read and ECC is checked. If L=1, then the ECC check bytes are not computed. Instead, the ECC check bytes are loaded into the buffer immediately after the data field. The external sector buffer must be long enough to hold the additional 7 bytes.

#### NOTE

This command supports only soft sector MFM and RLL mode and is implemented for backward compatibility with the WD5011 and WD5011A.

## Command Flow:

- · MICRO:
- Set DRWB = 0 (bit 2) in the buffer manager control register (37<sub>16</sub>).
- Load the starting address of the first sector into the disk buffer pointer registers (34<sub>16</sub> & 35<sub>16</sub>).
- Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- Set ECCM = 0 (bit 7) and DDRQ = 1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC=1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI, if desired.
- 5. Set MAC=0 in the drive interface control register.
- 6. Issue read next data command to WD42C22C.
- WD42C22C: 7.
  - Write FF to alternate sector number register (3C<sub>16</sub>). Abort if drive not ready or write fault.
  - (If DRQI is enabled)Set DRQ status bit, activate

BDRQ signal to buffer manager. Wait for BRDY signal indicating transfer of buffer pointer.

- MICRO: Set RDQI (bit 1) in the interface control register (38<sub>16</sub>).
- WD42C22C: 9. Find next data field, read sector data and place in buffer. If data mark error, try data field search again until 2 index pulses occur.
  - Copy sector number register to alternate sector number register (3C<sub>16</sub>). Set DCI (bit 3) in the interface status register (38<sub>16</sub>). MCINT is asserted.
- MICRO: 11. Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

## **Error Flags:**

- Drive not ready and aborted command set if drive not ready.
- Write fault and aborted command set if WF pin activated.
- Data CRC/ECC set if data field CRC or ECC check fails. No correction is attempted.
- Data AM not found is set if data address mark not found after 2 index pulses of looking for any data field.

#### 4.4.3 Write Sector

Write from buffer to disk when BRDY signal is activated by the buffer manager. Write total number of sectors specified by sector count register if M=1. Sectors are written in numerical order. If M=0, then sector count is ignored and only one sector is written. The data field PLO sync field is nominally 12 bytes long but is extended by the PLO register.

If T = 0, then ID searches are retried for 10 index pulses. If T = 1, then ID searches are retried for 2 index pulses only.

If L=0, then normal CRC or ECC write sector commands are performed. If L=1, then the CRC or ECC check bytes are not computed and written to the disk but instead, 4 or 7 additional bytes are

read from the buffer and written to the disk immediately after the data field.

If X=0, then the controller searches for the sector number in the sector number register and increments the sector number register and the end of each sector if M=1. If X=1, then the controller searches for the sector specified in the first byte of the sector buffer. The controller reloads the sector number register from the first byte of each subsequent sector buffer if M=1. This allows a track formatted with interleave to be written in one revolution.

A bad block mark in the ID field sets the error bit and the data field is not be written. If the R option in the set parameter command is set, then the controller searches immediately after the normal ID field for a special ID field containing mapping information and a special "Relocation ID" flag bit. The RIDF bit in the error register sets if this special ID field is found. If a bad block mark is found in an ID field then the command terminates immediately even if more sectors remain to be read. The task file contents when a bad block bit is detected and the R option is used is as follows:

| REGISTER | MEANING                                                |
|----------|--------------------------------------------------------|
| 22       | Sector number of sector with bad block bit set         |
| 23       | Sector number where sector<br>has been relocated       |
| 24       | LSB of cylinder number where sector has been relocated |
| 25       | MS bits of cylinder where sector has been relocated    |
| 26       | Head number where sector has been relocated            |

If DSN = 1(bit 0) in the drive interface control register ( $3B_{16}$ ) then the sector number is not compared when ID searches are performed. The WD42C22C writes the sector as long as the cylinder and head numbers match the desired values. This allows an interleaved track to be written into the buffer in one revolution. This option is only useful when doing the initial write-after-format to place 00 in the data fields.

#### Command Flow:

- MICRO:
- Set DRWB = 1 (bit 2) in the buffer manager control register (37<sub>16</sub>).

- Load the starting address of the first sector into the disk buffer pointer registers (34<sub>16</sub> & 35<sub>16</sub>).
- Set ECCM = 0 (bit 7) and DDRQ = 1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC = 1 (bit 3) in the drive register (3B<sub>16</sub>) to disable DRQI, if desired.
- Set ADBP=1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- Set MAC = 0 in the drive interface control register.
- 6. Issue write command to WD42C22C.
- WD42C22C: 7. Write FF to alternate sector number register (3C<sub>16</sub>). Abort if drive not ready or write fault.
  - (If DRQ is enabled.)
     Activate BDRQ signal to buffer manager and DRQI to microcontroller. Wait for BRDY signal indicating transfer of buffer pointer.
- Load starting address of next sector buffer into disk buffer pointer register. Set ADBP=1 in buffer manager control register if more sectors remaining. Set RDQI (bit 1) in the interface control register (38<sub>16</sub>).
- WD42C22C: 9. Search for head, cylinder, sector number and sector size code.
  - When the proper sector ID is found, write buffer data to sector.
  - Write sector number to alternate sector number register (3C<sub>16</sub>). If M = 0 then go to 13.
  - Decrement sector count, increment sector number. If
     M = 1 and sector count = 0
     then go to 13 else go to step
     8.
  - Set DCI (bit 3) in the interface status register (38<sub>16</sub>).
     MCINT asserted.

**//** 

· MICRO:

 Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

### **Error Flags:**

- Drive not ready and aborted command set if drive not ready.
- Write fault and aborted command set if WF pin activated.
- ID not found set if exact ID field not found or if ID field matches but CRC check fails, after retry procedure.
- Bad Block set if write sector attempted on any sector with bad block mark.
- Relocation ID found if R option enabled and relocation ID detected

#### 4.4.4 Write ID

Write from buffer to disk when BRDY signal is activated by the buffer manager. Write 4 bytes to create an ID field. The PLO sync field prior to this new ID field is nominally 12 bytes long but is extended by the PLO register. A value of 0 results in a 2048 byte PLO field and should not be used.

If T=0 then ID searches are retried for 10 index pulses. If T=1, then ID searches are retried for 2 index pulses only.

If F=0, then the new ID is written immediately after the ID field of the desired sector. If F=1, then the new ID field is written offset from the desired sector ID with the offset determined by the internal sector size register. A load parameter block command will have to be issued to set the offset value and another load parameter block will be needed to set the sector size back to the correct value if the programmable sector size option is being used. An offset of up to 2048 is allowed. This option can be used to reformat a single sector in soft sector mode.

If A=0, then the AME output is held low during the write ID command. If A=1, then the AME output is pulsed at the start of the PLO field before the new ID being written. This option, together with the F option, can be used to reformat a single sector in soft sector NRZ mode.

The four bytes in the buffer (F = 0) should be as follows:

BYTE 0: 1 1 1 1 cyl 10 1 cyl 9 cyl 8

BYTE 1: Low byte of cylinder number

BYTE 2: BB 0 RF 0 HS3 HS2 HS1 HS0

BYTE 3: Sector Number

BB = bad block flag

RF = Relocation ID flag

cyl 10 thru cyl 8 = upper three cylinder number bits

HS3 thru HS0 = head select bits

The five bytes in the buffer (F = 1) should be as follows:

BYTE 0: Sector Number

BYTE 1: 1 1 1 1 cyl 10 1 cyl 9 cyl 8

BYTE 2: Low byte of cylinder number

BYTE 3: BB 0 RF 0 HS3 HS2 HS1 HS0

BYTE 4: Sector Number

BB = bad block flag

RF = Relocation ID flag

cyl 10 thru cyl 8 = upper three cylinder number bits

HS3 thru HS0 = head select bits

RF should be set to 1 if the new ID being written is to be a special relocation ID for mapping a defective sector to a new position.

## Command Flow:

- · MICRO:
- Set DRWB = 1 (bit 2) in the buffer manager control register (37<sub>16</sub>).
- Load the starting address of the ID buffer data into the disk buffer pointer registers (34<sub>16</sub> & 35<sub>16</sub>).
- Set ECCM = 0 (bit 7) and DDRQ = 1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC = 1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI, if desired.

27

- 4. Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- Set MAC = 0 in the drive interface control register.
- 6. Issue Write ID command to WD42C22C.
- WD42C22C: 7. Write FF to alternate sector number register (3C<sub>16</sub>).
   Abort if drive not ready or write fault.
  - (If DRQI is enabled)
     Activate BDRQ signal to buffer manager and DRQI to microcontroller. Wait for BRDY signal indicating transfer of buffer pointer.
- MICRO: Set RDQI (bit 1) in the interface control register (38<sub>16</sub>).
- WD42C22C: 9. Search for head, cylinder, sector number and sector size code.
  - When the proper sector ID is found, write buffer data to sector
- WD42C22C:11. Write sector number to alternate sector number register.
   Set DCI (bit 3) in the interface status register (38<sub>16</sub>).
   MCINT asserted.
- MICRO: 12. Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

## **Error Flags:**

- Drive not ready and aborted command set if drive not ready.
- Write Fault and aborted command set if WF pin activated.
- ID not Found set if exact ID field not found or if ID field matches but CRC check fails, after retry procedure.
- Bad Block set if bad block bit detected in ID of desired sector.

#### 4.4.5 Scan ID

When the next ID field of the present track is encountered, cylinder number, sector size, head number and sector number are loaded into the respective registers.

#### Command Flow:

- · MICRO:
- Issue Scan ID command to WD42C22C.
- WD42C22C 2. Write FF to alternate sector number register (3C<sub>16</sub>).
   Abort if drive not ready or write fault.
  - Search for next ID field and read 4 ID bytes into respective registers. Search for ID field for up to 10 index pulses if T=0, up to 2 index pulses if T=1
  - Set DCI (bit 3) in the interface <u>status</u> register (38<sub>16</sub>).

     MCINT asserted.
- · MICRO:
- Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

## **Error Flags:**

- Drive not ready and aborted command set if drive not ready.
- Write fault and aborted command set if WF pin active
- · Bad Block set if bad block mark detected.
- . ID not found if no ID fields are found.
- Relocation ID found if R option enabled and relocation ID detected.

#### 4.4.6 Format Track

This command formats one track using parameters loaded in the task registers file and in buffer memory.

Cylinder, head, and sector size numbers are taken from the task register file. Good block/bad block marks and sector numbers are taken from buffer memory. The total number of sectors formatted is specified by the sector count register. The lengths of GAP 1 and GAP 3 are loaded into the sector number register. The length of the ID PLO sync field is loaded into the PLO length register if B = 1. The data PLO field length is 12 bytes during format.

The data placed in the gaps comes from an internal register loaded during the load parameter block command. The data placed into the pads

//

comes from another internal register loaded during the load parameter block command.

After the task register file has been loaded with the desired format parameters and the block marks and sector addresses have been loaded into the buffer then the command register is loaded with the format command. When the BRDY signal is activated by the buffer manager. the specified number of sectors are written. The block marks and sector numbers are read from the buffer as needed. The data field is written with FF. CRC is automatically computed and written if in CRC mode. If in ECC mode, ECC check bytes are automatically computed and written after the data field. The number of ECC check bytes is determined by the E bit in the set parameter command.

Write Gate is turned on and off within 4 bit times after index if NRZ or hard sector mode is selected or within 6 bit times otherwise. In RLL mode. Gap1/Gap3 data should be programmed to be 33<sub>16</sub> with the load parameter command. The W option controls the state of WRITE GATE over the gaps. If W=1, WRITE GATE turns off over the gaps.

The sum of the number of bytes in both the Gap1/Gap3 and ID PLO field must be greater than or equal to 25 bytes to achieve 1.1 interleave.

The interleave table contains the bad block marks and sector numbers for the track. If there is a bad sector and it is desired for the controller to just skip over it, then the bad block mark for that sector position should be set to 8016 and the sector number for that sector should be set to FF16. If it is desired to map the bad sector then the bad block mark for that sector should be set to 8016 and the sector number for that sector should be set to the correct value for that position in the interleave table. The R and U options should be set in the set parameter and load parameter block commands. A write ID command then places the relocation information for that sector onto the drive.

The interleave table format is:

• BYTE 0:

1st sector's block mark

(00<sub>16</sub> or 80<sub>16</sub>)

BYTE 1:

1st sector's sector number

• BYTF 2:

2nd sector's block mark

(00<sub>16</sub> or 80<sub>16</sub>)

• BYTE 3:

2nd sector's sector number

· BYTE 2n:

nth sector's block mark

(0016 or 8016)

BYTE 2n+1:

nth sector's sector number

#### Command Flow:

· MICRO:

1. Set DRWB = 1 (bit 2) in the buffer manager control register (37<sub>16</sub>)

2. Load the starting address of the interleave table into the disk buffer pointer registers (3416 & 3516).

3. Set ECCM = 0 (bit 7) and DDRQ = 1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC = 1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI, if desired.

4. Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).

5. Set MAC = 0 in the buffer control register.

6. Issue format command to WD42C22C

 WD42C22C: 7. Write FF to the alternate. sector number register (3C<sub>16</sub>). Abort if drive not ready or write fault.

> 8. (If DRQI is enabled) Activate BDRQ signal to buffer manager and DRQI to microcontroller. Wait for BRDY signal indicating transfer of buffer pointer. Wait for leading edge of index.

· MICRO:

Set RDQI (bit 1) in the interface control register (3816).

 WD42C22C: 9. Write gap.

> 10. Write sector ID using parameters in task register file and buffer memory. Data bytes are FF.

27

- Decrement sector count register. If sector count = 0, then go to step 12, else go to step 9.
- Write Gap until leading edge of index pulse.
- 13. De-assert Write Gate.
- Set DCI (bit 3) in the interface status register (38<sub>16</sub>).
   MCINT asserted.
- · MICRO:
- Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

### **Error Flags:**

- Drive not ready and aborted command set if drive not ready.
- Write fault and aborted command set if WF pin activated.

#### Note

Gap length written on disk is 3 bytes longer than gap value specified in sector number register.

#### 4.4.7 Format Single Sector

This command formats one sector using parameters loaded in the task register file and in buffer memory. This command only applicable to hard sector mode.

WRITE GATE is turned on and off within 4 bit times after index or sector if NRZ mode is selected or within 6 bit times otherwise. The W option controls the state of WRITE GATE over the gaps. Setting W to 1 turns off WRITE GATE over the gaps.

Cylinder, head, and sector size numbers are taken from the task register file. Good block/bad block marks and sector number are taken from buffer memory. The physical sector position to be formatted is specified by the sector count register. If sector count = 1, then the first sector after index is formatted. For sector count = 2, the second sector after index is formatted, and so on. The lengths of GAP 1 and GAP 3 are loaded into the sector number register. The length of the ID PLO sync field is loaded into the PLO length register.

The data placed in the gaps comes from an internal register loaded during the load parameter block command. The data placed into the pads comes from another internal register loaded during the load parameter block command.

After the task register file has been loaded with the desired format parameters and the block marks and sector number loaded into the buffer, then the command register is loaded with the format single sector command. When the BRDY pin is activated by the buffer manager, the controller then looks for the start of the desired sector. The bad block mark and sector number are read from the buffer. The data field is written with FF. CRC is automatically computed and written if in CRC mode. If in ECC mode, ECC check bytes are automatically computed and written after the data field. The number of ECC check bytes is determined by the E bit in the set parameter command.

The data for the buffer is:

- BYTE 0: bad block mark (00<sub>16</sub> or 80<sub>16</sub>)
- BYTE 1: sector number of formatted sector.

#### Command Flow:

- · MICRO:
- Set DRWB = 1 (bit 2) in the buffer manager control register (37<sub>16</sub>).
- Load the starting address of the interleave table into the disk buffer pointer registers (34<sub>16</sub> & 35<sub>16</sub>).
- Set ECCM=0 (bit 7) and DDRC =1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC=1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI, if desired.
- Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- Set MAC=0 in the drive interface control register.
- Issue format single sector command to WD42C22C.
- WD42C22C: 7. Write FF to the alternate sector number register (3C<sub>16</sub>).
   Abort if drive not ready or write fault.
  - (If DRQI is enabled)
     Activate BDRQ signal to buffer manager and DRQI to microcontroller. Wait for BRDY signal indicating transfer of buffer pointer. Wait for leading edge of index.

**//**//

27-49

• MICRO: Set RDQI (bit 1) in the interface control register (38<sub>16</sub>).

• WD42C22C: 9. Decrement sector count. If sector count = 0 go to 11, else go to 10.

10. Wait for SECTOR pulse, then go to 9.

Assert WRITE GATE. Write gap.

WD42C22C:12. Write sector ID using parameters in task register file and buffer memory. Data bytes are FF.

13. Write gap until leading edge of SECTOR pulse.

14. De-assert Write Gate.

15. Set DCI (bit 3) in the interface status register (38<sub>16</sub>). MCINT asserted.

 MICRO: 16. Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

### **Error Flags:**

- Drive not ready and aborted command set if drive not ready.
- Write fault and aborted command set if WF pin activated.

#### 4.4.8 Compute Correction

This command is used to compute the pattern and location of a single burst error. It is used after a read sector command has detected a data field ECC error. The compute correction command first writes the four or seven syndrome bytes into the buffer. It then processes the syndrome bytes to compute the error pattern and error location. The error location and error pattern bytes are written into the buffer. Either four or seven error pattern bytes are written to the buffer depending on the ECC length selected. The error pattern bytes are automatically byte aligned.

The P option is used to control whether or not the error pattern bytes are calculated. If P=0, then the error pattern bytes are calculated and sent to the buffer. If P=1, then the error pattern bytes are not calculated. Only the syndrome byte is transferred to the buffer. This option facilitates firmware algorithms that require a matching syndrome before a correction is made. In this case, the firmware calculates the error pattern, corrects the

error, and saves the syndrome after initially detecting the error. Then, the firmware dumps and compares the syndrome on the second read of the same sector. An ECC error can now be corrected in one revolution of the disk compared to three revolutions required by earlier WD1010 and WD2010 based controllers.

The error pattern and error location bytes are not valid if the error is found to be uncorrectable. An uncorrectable error is indicated by the appropriate bits in the status and error register.

The buffer contents contains the following information:

- · SYNDROME BYTE (MSB)
- SYNDROME BYTE
- SYNDROME BYTE
- SYNDROME BYTE (LSB if 4 byte ECC)
- SYNDROME BYTE (if 7 byte ECC)
- SYNDROME BYTE (if 7 byte ECC)
- SYNDROME BYTE (LSB if 7 byte ECC)
- BYTE OFFSET (MSB)
- BYTE OFFSET (LSB)
- ERROR PATTERN (MSB)
- ERROR PATTERN
- ERROR PATTERN
- ERROR PATTERN (LSB if 4 byte ECC)
- ERROR PATTERN
- ERROR PATTERN
- ERROR PATTERN (LSB if 7 byte ECC)

If the byte offset is 0, then the first data byte of the sector should be exclusive OR'ed with the first error pattern byte (MSB). Each succeeding data byte exclusive OR'ed with the succeeding error pattern byte until the fourth data byte is exclusive OR'ed with the fourth error pattern byte (LSB). Exclusive OR the first two error pattern bytes for 5 bit spans. Exclusive OR the first three error pattern bytes for 11 bit spans. Exclusive OR the first four error pattern bytes for the 22 bit span.

#### Command Flow:

- · MICRO:
- 1. Set DRWB=0 (bit 2) in the buffer manager control register (37<sub>16</sub>).
- Load the starting address of the error correction data buffer into the disk buffer pointer

27

- registers (34<sub>16</sub> & 35<sub>16</sub>).
- Set ECCM=0 (bit 7) and DDRQ =1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC=1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI, if desired.
- 4. Set ADBP=1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- 5. Set MAC=0 in the drive interface control register.
- 6. Issue compute correction command to WD42C22C.
- WD42C22C: 7. Write FF to the alternate sector number register (3C<sub>16</sub>).
   Abort if drive not ready or write fault.
  - (If DRQI is enabled)
     Activate BDRQ signal to buffer manager and DRQI to microcontroller. Wait for BRDY signal indicating transfer of buffer pointer.
- MICRO: Set RDQI (bit 1) in the interface control register (38<sub>16</sub>).
- WD42C22C: 9. Transfer contents of the four (or seven) byte ECC register to buffer, most significant byte
  - Clock the ECC register. Stop
    if correctable pattern found or
    if number of clocks exceeds
    sector size. If number of
    clocks exceeds sector size,
    set error bit of status register
    and ECC error of error register
  - Transfer byte count to buffer (2 bytes). Transfer 4 bytes of error pattern to buffer if 4 byte ECC. Transfer 7 bytes of error pattern 7 byte ECC.
  - Set DCI (bit 3) in the interface <u>status register (38<sub>16</sub>).</u>

     MCINT asserted.
- MICRO: 13. Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

### **Error Flags:**

CRC/ECC flag set if data field error length exceeds correction span.

#### NOTE

Default 11 bit correction span after master reset if 7-byte ECC or 5 bit correction span if 4-byte ECC.

#### 4.4.9 Set Parameter

The E bit is used to select either 4 byte or 7 byte sector extension for read long and write long commands. It also selects either a 4 or 7 byte internally generated ECC. A 7 byte sector extension and 7 byte ECC are the default after a master reset (due to RLL default). If E is 0, then a 4 byte sector extension and 4 byte ECC are selected if MFM or NRZ mode. If E is 1, then a 7 byte sector extension and 7 byte ECC are selected.

The H bit selects either 3 or 4 head select bits in the SDH register. If H=0, then 3 head select bits are written or compared in the ID fields on the drive. If H=1, then 4 head select bits are written or compared in the ID fields on the drive. The default after master reset is 3 head select bits.

The S bit is used to select either a 5 bit or 11 bit correction span if 4 byte ECC and an 11 bit or 22 bit correction span if 7 byte ECC. An 11 bit correction span for 7 byte ECC is the default parameter following master reset. If S is 0, then a 5 bit correction span is selected if 4 byte ECC, 11 bit correction span if 7 byte ECC. If S is 1, then an 11 bit correction span is selected if 4 byte ECC, 22 bit correction span if 7 byte ECC.

The Z bit is used to select MFM, RLL, or NRZ mode. If K=0 in the load parameter block command, then RLL coding is selected regardless of the state of Z. If Z is 0 and K is 1, then MFM coding is selected. If Z is 1 and K=1, then NRZ coding is selected.

The R option is used to enable relocation ID searches. If R=1 for read and write sector commands and a bad block mark is detected in the desired sector's ID, then the WD42C22C searches for a special ID field containing relocation information immediately after the desired sector's ID. This special ID field is placed using the write ID command. When the R option is used, then the U option must be set to 1 in the load parameter block command.

#### Command Flow:

· MICRO:

Issue set parameter command to WD42C22C.

WD42C22A: 2.

Write FF to the alternate sector number register (3C<sub>16</sub>).

Abort if drive not ready or write fault.

- 3. Set or reset internal parameter flip-flop.
- Set DCI (bit 3) in the interface <u>status</u> register (38<sub>16</sub>).

   MCINT asserted.

MICRO:

 Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

#### **Error Flags:**

· None.

#### 4.4.10 Load Parameter Block

The D bit is used to indicate the sectoring mode. If D = 0, the default after a master reset, then soft sector mode is selected. If D = 1, then hard sector mode is selected. In hard sector mode, the PLO length register is transferred to the internal GAP length register during the load parameter block command. This GAP register is used to control the delay from INDEX/SECTOR to READ GATE on.

The K bit selects the data interface mode. If K=0, the default after a reset, then RLL mode is selected. If K=1, then the interface is either MFM or NRZ as selected by the set parameter command.

The U bit selects the sector size options. If U=0, then the sector sizes are 128, 256, 512, and 1024 depending on the contents of the SDH register. If U=1, then the sector size is defined by the user. The cylinder registers are loaded with the desired sector size prior to issuing the load parameter block command.

In addition, the load parameter block command is used to load several internal parameters for format, read, and write commands. The task file is loaded with these parameters prior to the start of the command. The registers loaded and the corresponding parameters are:

| REGISTER | PARAMETER                                                          |
|----------|--------------------------------------------------------------------|
| 21       | Delay from INDEX/SECTOR to RG                                      |
| 22       | Data written in GAPS                                               |
| 23       | Data written in PADS                                               |
| 24       | LS byte of sector size, LS byte of offset for write ID command     |
| 25       | 3 MS bits of sector size, 3 MS bits of offset for write ID command |

#### Command Flow:

· MICRO:

- 1. Load parameters into task file.
- Issue load parameter block command to WD42C22C.

WD42C22C: 3.

- Write FF to the alternate sector number register (3C<sub>16</sub>).
   Abort if drive not ready or write fault.
- 4. Set or reset internal parameter flip-flop.
- Copy cylinder registers to internal sector size register.
   Copy PLO register to internal GAP register. Copy sector count register to internal GAP data register. Copy sector number register to internal PAD data register.
- Set DCI (bit 3) in the interface <u>status</u> register (38<sub>16</sub>).
   MCINT asserted.

· MICRO:

 Read disk controller status register (27<sub>16</sub>) and error register (21<sub>16</sub>).

## **Error Flags:**

None.

## 27

### 4.4.11 Sleep

The sleep command places the WD42C22C in a low power standby mode. When the sleep command is issued, the disk controller section clocks are disabled and only the buffer manager and host interface logic is enabled. The disk controller can be brought out of the sleep mode by setting RDC = 1 (bit 7) in the disk controller control register (3B<sub>16</sub>) or by resetting the entire WD42C22C. The microcontroller should **NEVER** attempt to read or write the drive controller task file (registers  $21_{16}$  through  $27_{16}$ ) while the drive controller is in the sleep mode.

#### **Command Flow:**

· MICRO:

- Issue sleep command to WD42C22C.
- WD42C22C: 2.
- 2. Write FF to the alternate sector number register (3C<sub>16</sub>).
  - 3. Disable drive controller clocks.

· MICRO:

 Wake up disk controller by setting RDC=1 or by resetting the WD42C22C.

### **Error Flags:**

- · None.
- . . .

#### 4.4.12 Dump

The dump command sends data off the media regardless of matching ID fields and regardless of the format. The command can dump an ID field, a data field, or both. Dump retrieves all the ID fields from index to index to determine the interleave. Dump can also read the ESDI standard defect list. The command dumps data starting at the first byte after the A1 sync byte for WD format or the first byte after the FE sync byte for ESDI format. This command can only do multisector dumps in hard sector mode.

The command is assumed to be a multisector command. To read just one sector as in an ESDI defect list read, then the sector count must be set to one. There are three options.

The I option controls the number of fields that are dumped for each sector. If I = 0, then two fields (ID and data) are dumped for each sector. If I = 1, then only one field is dumped for each sector. The type of field is determined by the read gate delay and the sector size. The sector size should be

programmed to 1 less than the number of bytes to be dumped for the sector.

The B option controls the sync byte and CRC preset. If B=0, then the sync byte is assumed to FE and the CRC is preset to all zeroes. If B=1, then the sync byte is assumed to be A1 and the CRC is preset to all ones.

The L option selects either CRC or no CRC checking. If L=0, then CRC is checked. If L=1, then either four or seven check bytes are transferred to the buffer depending on the extension selected by the set parameter command. If L=1, then I should also be set to 1. B does not affect the L option.

The PLO register controls the read gate delay for the first sector. READ GATE turns on x + 5 + CL bytes after the index pulse. Read gate for subsequent sectors is controlled as in normal read and write commands.

Use the dump command to read an ESDI defect list as follows:

- 1. Set PLO register = read gate delay 5.
- 2. Set sector size = 255 for 256 byte sector.
- 3. Issue A1 command.

Use the dump command to dump the track interleave for WD format as follows:

- Set PLO register = read gate delay 5.
- 2. Set sector size = 4.
- Set sector count = number of sectors per track.
- 4. Issue AD command.

Use the dump command to dump all the data fields on a track for WD format as follows:

- Set PLO register = read gate delay to start of data PLO - 5.
- Set sector size = actual number of bytes per sector.
- Set sector count = number of sectors per track.
- 4. Issue AF command or AB command. In this case, the F8 second data sync byte is transferred to the buffer. The buffer requires one extra byte per sector.

One BRDQ interrupt occurs at the very beginning of the command. Therefore, the buffer must be contiguous and large enough to handle all the dumped sectors.

#### Command Flow:

- MICRO:
- Set DRWB = 0 (bit 2) in the buffer manager control register (3716).
- 2. Load the starting address of the buffer into the disk buffer pointer register (34<sub>16</sub> & 35<sub>16</sub>).
- 3. Set ECCM = 0 (bit 7) and DDRQ = 1 (bit 6) in the DIR write register (3F<sub>16</sub>) and MAC = 1 (bit 3) in the drive interface control register (3B<sub>16</sub>) to disable DRQI. if desired.
- 4. Set ADBP = 1 (bit 0) in the buffer manager control register (37<sub>16</sub>).
- 5. Set MAC = 0 in the drive interface control register.
- 6. Issue dump command to WD42C22C
- WD42C22C 7. Write FF to alternate sector number register (3C<sub>16</sub>). Abort if drive not ready or write fault.
  - 8. (If DRQI is enabled) Activate BDRQ signal to buffer manager and DRQI to microcontroller. Wait for BRDY indicating transfer of buffer pointer.
- · MICRO:
- Set RDQI (bit 1) in the interface control register (38<sub>16</sub>).
- WD42C22C: 9. Wait for index.
  - 10. If I=1, then go to 12 else go
  - 11. Search for sync byte. When found, dump 5 data bytes into buffer.
  - 12. Search for sync byte. When

- found, dump programmed number of bytes into the buff-
- 13. Decrement sector count. If sector count = 0, then go to 14 else go to step 10.
- 14. Set DCI (bit 3) in the interface status register (3816). MCINT asserted
- MICRO:
- 15. Read disk controller status register (27<sub>16</sub>) and errror register (21<sub>16</sub>).

## **Error Flags:**

- · Drive not ready and aborted command set if drive not ready.
- · Write fault and aborted command set if WF pin activated
- ID not found set if I = 0 and index detected. while searching for an ID field or if CRC of ID field doesn't zero.
- · Data AM not found is set and index is detected while searching for a data field. If I=0 or when searching for either an ID or data field when l = 1.
- · Data CRC if the data field CRC doesn't zero when I = 0 or if either an ID or data field CRC doesn't zero when l = 1

## 5.0 ELECTRICAL AND TIMING SPECIFICATIONS

#### 5.1 MAXIMUM RATINGS

| V <sub>CC</sub> with respect to V <sub>SS</sub> (ground) | +5 V ± 5%                     |
|----------------------------------------------------------|-------------------------------|
| Max voltage on any pin with respect to Vss               | 0.5V to 5.5                   |
| Operating temperature (T <sub>A</sub> )                  | 0°C (32°F) to 70°C (158°F)    |
| Storage temperature                                      | 55°C (-67°F) to 125°C (257°F) |

#### NOTE

Maximum limits where permanent device damage occurs. Continuous operation at these limits is not intended and should be limited to those conditions specified in the DC operating characteristics.

#### 5.2 DC OPERATING CHARACTERISTICS

| SYMBOL         | CHARACTERISTIC                          | MIN    | MAX    | UNITS    | CONDITIONS                                                                                     |
|----------------|-----------------------------------------|--------|--------|----------|------------------------------------------------------------------------------------------------|
| HL             | Input Leakage                           |        | ±10    | μΑ       | V <sub>IN</sub> = 0.4 to V <sub>CC</sub>                                                       |
| loz            | Tri-state and open drain output leakage |        | ±10    | μΑ       | V <sub>OUT</sub> = 0.4 TO V <sub>CC</sub>                                                      |
| VIH            | Input High Voltage                      | 2.0    |        | V        |                                                                                                |
| VIL            | Input Low Voltage                       |        | 0.8    | V        |                                                                                                |
| Vон            | Output High Voltage                     | 2.4    |        | V        | I <sub>OUT</sub> =-800 μ <b>A</b>                                                              |
| VoL            | Output Low Voltage                      |        | 0.4    | V        | I <sub>OUT</sub> =2.0 mA                                                                       |
| lcc            | Supply Current                          |        | 100    | mA       | All outputs open.                                                                              |
| lccs           | Supply Current (Standb) Mode)           | y      | 25     | mA       | All inputs at V <sub>DD</sub> or V <sub>SS</sub> , disk controller sleep mode, 15 MHz crystal. |
| For pins 75 th | ough 82, 40 through 42, 4               | 14 thr | ough 4 | 8, 74, 8 | · ·                                                                                            |

#### **TABLE 14. DC OPERATING CHARACTERISTICS**

(HD0 through HD15, INTRQ, DREQ):

| SYMBOL | CHARACTERISTIC      | MIN MAX | UNITS | CONDITIONS             |
|--------|---------------------|---------|-------|------------------------|
| Voh    | Output High Voltage | 2.4     | V     | I <sub>OUT</sub> =-5mA |
| VoL    | Output Low Voltage  | 0.4     | V     | I <sub>OUT</sub> =12mA |

For pin 8 (IOCS16, AT PIO mode only):

| SYMBOL | CHARACTERISTIC     | MIN MAX | UNITS | CONDITIONS             |
|--------|--------------------|---------|-------|------------------------|
| Vol    | Output Low Voltage | 0.4     | ٧     | l <sub>O</sub> =20.0mA |

1/2

12/4/90 27-55

For pins 10, 11, and 12 (WD, EARLY, LATE):

| SYMBOL | CHARACTERISTIC      | MIN | MAX | UNITS | CONDITIONS             |
|--------|---------------------|-----|-----|-------|------------------------|
| Voн    | Output High Voltage | 2.4 |     |       | l <sub>O</sub> =-800μA |
| Vol    | Output Low Voltage  |     | 0.4 | V     | I <sub>O</sub> =6.0mA  |

## For pin 22 (RESET)

| SYMBOL          | CHARACTERISTIC     | MIN MAX | UNITS | CONDITIONS                                                                                 |
|-----------------|--------------------|---------|-------|--------------------------------------------------------------------------------------------|
| V <sub>OL</sub> | Output Low Voltage | 0.4     | V     | I <sub>O</sub> =6.0 mA and VDD at spec.<br>IO=2.0 mA and VDD at VRST2<br>max<br>VRST3 max. |

## For pins 36, 37 (DS0, DS1):

| SYMBOL | CHARACTERISTIC     | MIN MAX | UNITS | CONDITIONS              | - |
|--------|--------------------|---------|-------|-------------------------|---|
| Vol    | Output Low Voltage | 0.4     | ٧     | I <sub>O</sub> =48.0 mA |   |

## For pins 59-73 (BA0-B14)

| SYMBOL | CHARACTERISTIC                        | MIN MAX | UNITS | CONDITIONS             |
|--------|---------------------------------------|---------|-------|------------------------|
| IPD    | Pulldown Current in read config. mode | 40 160  | μΑ    | V <sub>OUT</sub> =2.4V |

For pins 5, 6, 9 (HRE, HWE, and DACK in slave host mode) and pins 40-42, 44-48 (HD8 through HD15 in 8-bit host mode):

| SYMBOL | CHARACTERISTIC | MIN MAX  | UNITS | CONDITIONS                         |  |
|--------|----------------|----------|-------|------------------------------------|--|
| lpu    | Pullup Current | 100 2000 | μΑ    | $V_{OUT}$ =0.4 V, $V_{DD}$ =5.25 V |  |

#### For pin 38 (XTALIN when driven by external osc.):

| SYMBOL          | CHARACTERISTIC     | MIN MA | X UNITS | CONDITIONS |
|-----------------|--------------------|--------|---------|------------|
| V <sub>IH</sub> | Input High Voltage | 3.5    | V       |            |
| VIL             | Input Low Voltage  | 1.0    | ) V     |            |



FIGURE 6. POWER QUALIFIED RESET VOLTAGE THRESHOLD

For pins 1-7, 9, 15, 16, 20, 21, 23, 25-35, 40-42, 44-48, 51-58, 59-73, 74, 75-82 (HA0-HA2, HA9, HRE, HWE, HCS, DACK, INDEX, SCT, WF, DRDY, RESET, ALE, MRE, MWE, AD0-AD7, HD8-HD15, BD0-BD7, BA0-BA15, INTRQ, HD0-HD7)

| SYMBOL    | CHARACTERISTIC              | MIN MAX | UNITS | CONDITIONS |
|-----------|-----------------------------|---------|-------|------------|
| VIH / VIL | Input Voltage<br>Hysteresis | 400     | mV    |            |

## For pin 84 (V<sub>DD</sub>)

| SYMBOL            | CHARACTERISTIC        | MIN | MAX | UNITS | CONDITIONS    |
|-------------------|-----------------------|-----|-----|-------|---------------|
| V <sub>RST1</sub> | Power Qualified Reset | 0.0 | 2.0 | ٧     | See Figure 7. |
| $V_{RST2}$        | Voltage Threshold     | 2.5 | 4.6 | V     | <b>3</b>      |
| $V_{RST3}$        | •                     | 2.5 | 4.6 | V     |               |
| $V_{RST4}$        |                       | 0.0 | 2.0 | V     |               |

#### 5.3 AC TIMING CHARACTERISTICS

#### NOTE

Load capacitance=50 pF each for all other outputs. Timings must be derated for larger load capacitances.

For pins 14, 16, 17, 19 (WC, DRUN, RD, RC):

| SYMBOL          | CHARACTERISTIC | MIN MAX | UNITS | CONDITIONS |
|-----------------|----------------|---------|-------|------------|
| t <sub>RS</sub> | Rise Time      | 10      | nsec  | 10% to 90% |



FIGURE 7. AT/XT HOST PROGRAMMED I/O WRITE TIMING

## NOTE

 $\frac{A \text{ write}}{HWE}$  occurs during the overlap of  $\overline{HCS}$  and  $\overline{HWE}$ .

27-58 12/4/90

## 5.3.1 AT/XT Host Programmed I/O Write Timing

| SYMBOL          | CHARACTERISTIC                    | MIN        | MAX | UNITS | CONDITIONS                                                       |
|-----------------|-----------------------------------|------------|-----|-------|------------------------------------------------------------------|
| tasw            | Address Setup to<br>HWE Low       | 30         |     | ns    |                                                                  |
| tcsw            | HCS Setup to HWE<br>Low           | 10         |     | ns    |                                                                  |
| t <sub>DS</sub> | Data Setup to HWE<br>High         | 30         |     | ns    | Port 0 only.                                                     |
| twe             | HWE Pulse Width                   | 75         |     | ns    | Port 0 only.                                                     |
| t <sub>DS</sub> | Data Setup to HWE<br>High         | 50         |     | ns    | All other ports.                                                 |
| twe             | HWE Pulse Width                   | 100        |     | ns    | All other ports                                                  |
| t <sub>DH</sub> | <u>Data</u> Hold from<br>HWE High | 15         |     | ns    |                                                                  |
| tahw            | ADDR Hold from HWE High           | 20         |     | ns    |                                                                  |
| tchw            | HCS Hold from HWE<br>High         | 10         |     | ns    |                                                                  |
| twen            | HCS and HWE Inactive              | 20         |     | ns    |                                                                  |
| twcy            | Write Cycle Time                  | 125<br>2*X |     | ns    | Port 0, XTAL>16 MHz<br>Port 0, XTAL<16MHz (X=t <sub>XTAL</sub> ) |
| twcy            | Write Cycle Time                  | 150        |     | ns    | All other ports                                                  |
| tcicsv          | IOCS16 valid from HCS             |            | 30  | ns    |                                                                  |
| taicsv          | IOCS16 valid from address         |            | 40  | ns    |                                                                  |
| tcicsi          | IOCS16 inactive from HCS          |            | 35  | ns    | Test circuit 1.                                                  |
| taicsi          | IOCS16 inactive from address      |            | 45  | ns    | Test circuit 1.                                                  |

TABLE 15. AT/XT HOST PROGRAMMED I/O WRITE TIMING



FIGURE 8. TEST CIRCUIT 1

**//**/

12/4/90

27-59



FIGURE 9. AT/XT HOST PROGRAMMED I/O READ TIMING

## 5.3.2 AT/XT Host Programmed I/O Read Timing

| SYMBOL | CHARACTERISTIC                             | MIN        | MAX                     | UNITS | CONDITIONS                                                        |
|--------|--------------------------------------------|------------|-------------------------|-------|-------------------------------------------------------------------|
| tase   | Address Setup to HRE Low                   | 30         |                         | ns    |                                                                   |
| tose   | HCS Setup to HRE Low                       | 10         |                         | ns    |                                                                   |
| tDAC   | Data Valid from HRE<br>Low                 |            | 60<br>70<br><b>1</b> 00 | ns    | Port 0, 8-bit.<br>Port 0, 16-bit.<br>All other ports.             |
| tre    | HRE Pulse Width                            | 75<br>100  |                         | ns    | Port 0<br>All other ports                                         |
| tрон   | Data Hold from HRE<br>High                 | 5          |                         | ns    |                                                                   |
| tHDTS  | <u>Data</u> Tri-state from<br>HRE          |            | 50                      | ns    |                                                                   |
| tHLD   | Addr <u>ess, HCS</u> Hold<br>from HRE High | 10         |                         | ns    |                                                                   |
| tRDR   | HCS and HRE Inact-<br>ive                  | 20         |                         | ns    |                                                                   |
| tRDCY  | Read Cycle Time                            | 125<br>2*X |                         | ns    | Port 0, XTAL>16 MHz<br>Port 0, XTAL<16 MHz (X=t <sub>XTAL</sub> ) |
| tRDCY  | Read Cycle Time                            | 150        |                         | ns    | All other ports.                                                  |
| tcicsv | IOCS16 Valid from HCS                      |            | 30                      | ns    |                                                                   |
| taicsv | IOCS16 Valid from<br>Address               |            | 40                      | ns    |                                                                   |
| toiosi | IOCS16 Inactive from HCS                   |            | 35                      | ns    | Test circuit 1                                                    |
| taicsi | IOCS16 Inactive from Address               |            | 45                      | ns    | Test circuit 1                                                    |

TABLE 16. AT/XT HOST PROGRAMMED I/O READ TIMING

## 5.3.3 AT/XT Host DMA Write Timing



FIGURE 10. AT/XT HOST DMA WRITE TIMING

| SYMBOL           | CHARACTERISTIC            | MIN MAX     | UNITS | CONDITIONS                                                         |
|------------------|---------------------------|-------------|-------|--------------------------------------------------------------------|
| tDLQL            | DACK Low to DRQ<br>Low    | 100         | ns    | BDEN=0                                                             |
| twhQL            | HWE High to DRQ<br>Low    | 4*X<br>+100 | ns    | BDEN=1. First transfer count throt-<br>tle. (X=t <sub>XTAL</sub> ) |
| tok              | DMA Cycle                 | 100<br>2*X  | ns    | XTAL=20MHz<br>Any XTAL (X=t <sub>XTAL</sub> )                      |
| tolwl            | DACK Low to HWE Low       | 0           | ns    |                                                                    |
| twn              | HWE Pulse Width           | 80          | ns    |                                                                    |
| tovwh            | Data Valid to HWE<br>High | 30          | ns    |                                                                    |
| twhdh            | HWE High to DACK High     | 0           | ns    |                                                                    |
| twhDi            | HWE High to Data Invalid  | 15          | ns    |                                                                    |
| t <sub>DWI</sub> | DACK and HWE In active    | 20          | ns    |                                                                    |

**TABLE 17. AT/XT DMA WRITE TIMING** 

## 5.3.4 AT/XT Host DMA Read Timing



FIGURE 11. AT/XT HOST DMA READ TIMING

| SYMBOL            | CHARACTERISTIC             | MIN MAX     | UNITS | CONDITIONS                                    |
|-------------------|----------------------------|-------------|-------|-----------------------------------------------|
| t <sub>DLQL</sub> | DACK Low to DRQ<br>Low     | 100         | ns    | BDEN=0                                        |
| trhal             | HRE High to DRQ<br>Low     | 4*X<br>+100 | ns    | BDEN=1. First TC throttle. (X=txtal)          |
| t <sub>DK</sub>   | DMA Cycle                  | 100<br>2*X  | ns    | XTAL=20MHz<br>Any XTAL (X=t <sub>XTAL</sub> ) |
| t <sub>DLRL</sub> | DACK Low to HRE Low        | 0           | ns    |                                               |
| t <sub>RD</sub>   | HRE Pulse Width            | 80          | ns    |                                               |
| t <sub>RLDV</sub> | HRE Low to Data<br>Valid   | 60<br>70    | ns    | 8-bit mode<br>16-bit mode                     |
| trhoh             | HRE High to DACK<br>High   | 0           | ns    |                                               |
| tohrh             | Data Hold from HRE<br>High | 5           | ns    |                                               |
| t <sub>RHDI</sub> | HRE High to Data tristate  | 50          | ns    |                                               |
| t <sub>DRI</sub>  | DACK and HRE Inactive.     | 20          | ns    |                                               |

**TABLE 18. AT/XT DMA READ TIMING** 

## 5.3.5 Slave Host Write Timings



FIGURE 12. SLAVE HOST WRITE TIMING

| SYMBOL         | CHARACTERISTIC                                       | MIN | MAX   | UNITS | CONDITIONS                                   |
|----------------|------------------------------------------------------|-----|-------|-------|----------------------------------------------|
| twhwL          | Address Port Write to<br>Data Write Recovery<br>Time | 120 | 10000 | ns    |                                              |
| tmwhal         | MWE to HALE Delay                                    |     | 150   | ns    |                                              |
| taval          | HD Address Setup to<br>HALE Low                      | 40  |       | ns    | AD setup to MWE (t <sub>ADVWH</sub> )=130 ns |
| talai          | HD Address Hold From<br>HALE low                     | 0   |       | ns    |                                              |
| talwl          | HALE Low To HWE<br>Low                               | 90  |       | ns    |                                              |
| tovwh          | HD Valid to HWE High                                 | 70  |       | ns    | AD setup to MWE (t <sub>ADVWH</sub> )=130 ns |
| twhDi          | HD Inactive from HWE                                 | 0   |       | ns    | (1.2.1.1)                                    |
| <b>t</b> MWHWL | MWE Low to HWE Low                                   |     | 150   | ns    |                                              |
| tmhwh          | MWE High to HWE<br>High                              |     | 150   | ns    |                                              |

**TABLE 19. SLAVE HOST WRITE TIMING** 

## 5.3.6 Slave Host Read Timings



FIGURE 13. SLAVE HOST READ TIMING

| SYMBOL | CHARACTERISTIC                                          | MIN MAX   | UNITS | CONDITIONS                                                                                                     |
|--------|---------------------------------------------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------|
| twhalh | Address Port Write to<br>ALE High Read<br>Recovery Time | 400 10000 | ns    | t <sub>HRLDV</sub> =210 ns                                                                                     |
| tmwhal | MWE to HALE Delay                                       | 150       | ns    |                                                                                                                |
| tmwhre | MWE to HRE Delay                                        | 150       | ns    |                                                                                                                |
| taval  | HD Address Setup to<br>HALE Low                         | 40        | ns    | AD setup to MWE (t <sub>ADVWH</sub> )=130 ns.                                                                  |
| talai  | HD Address Hold from<br>HALE Low                        | 0         | ns    |                                                                                                                |
| thdsa  | HD Data <b>Setup to</b> ALE<br>High                     | 40        | ns    |                                                                                                                |
| thdha  | HD Data <b>Hold from</b><br>ALE High                    | 40        | ns    |                                                                                                                |
| tmrhrh | MRE Low to HRE High<br>Delay                            | 0         | ns    |                                                                                                                |
| thrldv | HRE Low to HD Data<br>Valid Delay                       |           |       | threldy is a function of the slave peripheral device and only affects twhalh. twalh = tmwhre + threldy + thdsa |

**TABLE 20. SLAVE HOST READ TIMING** 

//

12/4/90

27-67



FIGURE 14. SLAVE HOST DMA WRITE TIMING

27-68

12/4/90

**//**2

#### 5.3.7 Slave Host DMA Write Timing

| SYMBOL            | CHARACTERISTIC                            | MIN<br>BIN 02<br>BIN 03<br>BIN 05 | MAX<br>BIN 02<br>BIN 03<br>BIN 05  | UNITS | CONDITIONS                                                |
|-------------------|-------------------------------------------|-----------------------------------|------------------------------------|-------|-----------------------------------------------------------|
| tsw1              | RCS Low to HWE First<br>Transfer of Burst | 0<br>0<br>0                       |                                    | ns    |                                                           |
| tsw2              | HD Valid to HWE Rising                    | 30<br>30<br>30                    |                                    | ns    |                                                           |
| tswз              | HWE Rising to HD Invalid                  | 15<br>15<br>15                    |                                    | ns    |                                                           |
| tsw4              | HWE Cycle Time                            | 200<br>200<br>100                 |                                    | ns    | txtal < tsw4 /<br>2                                       |
| tsw5              | HWE Low Pulse Width                       | 80<br>80<br>30                    |                                    | ns    |                                                           |
| tsw6              | HWE High Pulse                            | 30<br>30<br>30                    |                                    | ns    | :                                                         |
| tsw7              | HWE Rising to DRQ Low                     | <i>I</i>                          | 4*X + 100<br>4*X + 100<br>4*X + 50 | ns    | Intermediate<br>throttle. X =<br>txtal                    |
| tsw <sub>10</sub> | RCS Low to DREQ Low                       |                                   | 100<br>100<br>50                   |       | Throttle when transfer count < 16 or single transfer mode |
| tsw <sub>11</sub> | DACK Low to HWE Out<br>Tri-state          |                                   | 60<br>60<br>60                     | ns    | HSMB = 1                                                  |

**TABLE 21. SLAVE HOST DMA WRITE TIMING** 

The following notes apply to Figure 15.

#### NOTE 1

SBIC guarantees no transfer here at 5 MB/s transfer rate.

#### NOTE 2

SBIC guarantees no transfer here at 10 MB/s transfer rate.

#### NOTE 3

SBIC guarantees no transfer here.

Although four transfers may occur after the FIFO goes almost full at 10 MB/s and only 3 bytes remain at that time, the buffer manage guarantees that at least 1 additional transfer occurs out of the FIFO prior to the fourth host transfer after the almost full condition. This guarantees that no overrun condition occurs.



FIGURE 15. SLAVE HOST DMA READ TIMING

#### 5.3.8 Slave Host DMA Read Timing

| SYMBOL            | CHARACTERISTIC                                 | MIN<br>BIN 02<br>BIN 03<br>BIN 05 | MAX<br>BIN 02<br>BIN 03<br>BIN 05  | UNITS | CONDITIONS                                                |
|-------------------|------------------------------------------------|-----------------------------------|------------------------------------|-------|-----------------------------------------------------------|
| tsw <sub>1</sub>  | RCS Low to HD Valid<br>First Transfer of Burst | 0<br>0<br>0                       |                                    | ns    |                                                           |
| tsw2              | HRE Rising to HD Valid                         | 5<br>5<br>5                       | 180<br>180<br>180                  | ns    |                                                           |
| tsw3              | RCS Low to First HRE<br>Rising Edge            | 140<br>140<br>100                 |                                    | ns    |                                                           |
| tsw4              | HRE Cycle Time                                 | 200<br>200<br>100                 |                                    | ns    | txtal < tsw4 /<br>2                                       |
| tsw5              | HRE Low Pulse Width                            | 80<br>80<br>30                    |                                    | ns    |                                                           |
| tsw6              | HRE High Pulse                                 | 30<br>30<br>30                    |                                    | ns    |                                                           |
| tsw7              | HRE Rising to DRQ Low                          |                                   | 4*X + 100<br>4*X + 100<br>4*X + 50 | ns    | Intermediate throttle. X = t <sub>XTAL</sub>              |
| tsw <sub>10</sub> | RCS Low to DREQ Low                            |                                   | 100<br>100<br>50                   |       | Throttle when transfer count < 16 or single transfer mode |
| tsw11             | DACK Low to HRE Out<br>Tri-state               |                                   | 60<br>60<br>60                     | ns    | HSMB = 1                                                  |

**TABLE 22. SLAVE HOST DMA READ TIMING** 

The following notes apply to Figure 16.

#### NOTE 1

SBIC guarantees no transfer here at 5 MB/s transfer rate.

#### NOTE 2

SBIC guarantees no transfer here at 10 MB/s transfer rate.

### NOTE 3

SBIC guarantees no transfer here.

Although 4 transfers may occur after the FIFO goes almost full at 10 MB/s and only 3 bytes remain at that time, the buffer manage guarantees that at least 1 additional transfer occurs out of the FIFO prior to the fourth host transfer after the almost full condition. This guarantees that no overrun condition occurs.

# 5.3.9 Buffer RAM Write Timing (Internal Oscillator; XTAL = 8 to 25 MHZ)



FIGURE 16. BUFFER RAM WRITE TIMING (INTERNAL OSCILLATOR)

| SYMBOL             | CHARACTERISTIC                    | MIN<br>Bin 02<br>Bin 03<br>Bin 05                                                   | MAX | UNITS | CONDITIONS |
|--------------------|-----------------------------------|-------------------------------------------------------------------------------------|-----|-------|------------|
| tadcy              | Address Cycle Time                | 2*txtal-28<br>2*txtal-35<br>2*txtal-25                                              |     | ns    | Any XTAL   |
| <sup>†</sup> BASWH | Addres Setup to BWE High          | 2*txtal-40<br>2*txtal-55<br>2*txtal-35                                              |     | ns    | Any XTAL   |
| †BASWL             | Addres Setup to BWE Low           | 0.5*txtal-20<br>0.5*txtal-35<br>0.5*txtal-20                                        |     | ns    | Any XTAL   |
| t <sub>BW</sub>    | BWE Pulse Width                   | 1.5*t <sub>XTAL</sub> -30<br>1.5*t <sub>XTAL</sub> -35<br>1.5*t <sub>XTAL</sub> -25 |     | ns    | Any XTAL   |
| tBAHW              | Address Hold From<br>BWE High     | 5<br>5<br>5                                                                         |     | ns    | Any XTAL   |
| toswн              | Data Valid to BWE<br>High         | 1.5*t <sub>XTAL</sub> -40<br>1.5*t <sub>XTAL</sub> -60<br>1.5*t <sub>XTAL</sub> -35 |     | ns    | Any XTAL   |
| tDHW               | <u>Data</u> Hold from<br>BWE High | 10<br>10<br>10                                                                      |     | ns    | Any XTAL   |
| t <sub>DTSW</sub>  | Data Tri-state from BWE High      |                                                                                     | 50  | ns    | Any XTAL   |

TABLE 23. BUFFER RAM WRITE TIMING (INTERNAL OSCILLATOR)

#### 5.3.10 Buffer RAM Read Timing (Internal Oscillator; XTAL = 8 to 20 MHZ)



FIGURE 17. BUFFER READ TIMING (INTERNAL OSCILLATOR)

| SYMBOL                      | CHARACTERISTIC                           | MIN<br>20 MHz<br>12 MHz      | UNITS | CONDITIONS |
|-----------------------------|------------------------------------------|------------------------------|-------|------------|
| tadcy                       | Address Cycle Time                       | 72<br>125                    | ns    | Max XTAL   |
| tadcy                       | Address Cycle Time                       | 2*txtal-28<br>2*txtal-35     | ns    | Any XTAL   |
| tbasr                       | Address Setup to BOE High                | 72<br>125                    | ns    | Max XTAL   |
| tBASR                       | Address Setup to BOE High                | 2*txtal-28<br>2*txtal-35     | ns    | Any XTAL   |
| t <sub>BR</sub>             | BOE Pulse Width                          | 45<br>75                     | ns    | Max XTAL   |
| t <sub>BR</sub>             | BOE Pulse Width                          | 1.5*txtal-30<br>1.5*txtal-45 | ns    | Any XTAL   |
| tBAHR                       | Address Hold from BOE High               | 0<br>0                       | ns    | Any XTAL   |
| t <sub>RDS</sub>            | <u>Data</u> Setup to<br>BOE High         | 5<br>5                       | ns    | Any XTAL   |
| troh                        | <u>Data</u> Hold from<br>BOE High        | 10<br>10                     | ns    | Any XTAL   |
| t <sub>DHW</sub>            | Data Hold from<br>Address                | 10<br>10                     | ns    |            |
| All timings     1.5V levels | in this table <b>only</b> are refe<br>s. | renced to                    |       |            |

TABLE 24. BUFFER READ TIMING (INTERNAL OSCILLATOR)

12/4/90

**//**//



FIGURE 18. BUFFER RAM WRITE TIMING (EXTERNAL OSCILLATOR)

# 5.3.11 Buffer RAM Write Timing (External Oscillator; XTAL = 8 to 20 MHz)

| SYMBOL             | CHARACTERISTIC                                               | MIN<br>20 MHz<br>12 MHz                            | MAX | UNITS | CONDITIONS            |
|--------------------|--------------------------------------------------------------|----------------------------------------------------|-----|-------|-----------------------|
| tadcy              | Address Cycle Time                                           | 72<br>125                                          |     | ns    | Max XTAL              |
| tadcy              | Address Cycle Time                                           | 2*t <sub>XTAL</sub> -28<br>2*t <sub>XTAL</sub> -35 |     | ns    | Any XTAL              |
| t <sub>BASWL</sub> | Address Setup to BWE Low                                     | 5<br>5                                             |     | ns    | Max XTAL/<br>50% XTAL |
| tbaswl .           | Address Setup to BWE Low                                     | txch-20<br>txch-35                                 |     | ns    | Any XTAL              |
| tbaswh             | Address Setup to BWE High                                    | 60<br>105                                          |     | ns    | Max XTAL              |
| tbaswh             | Address Setup to BWE High                                    | 2*txtal-40<br>2*txtal-55                           |     | ns    | Any XTAL              |
| t <sub>BW</sub>    | BWE Pulse Width                                              | 55<br>85                                           |     | ns    | Max XTAL/<br>50% XTAL |
| t <sub>BW</sub>    | BWE Pulse Width                                              | txtal+txcl-30<br>txtal+txcl-35                     |     | ns    | Any XTAL              |
| tBAHW              | Address Hold from BWE High                                   | 5<br>5                                             |     | ns    | Any XTAL              |
| toswh              | Data Valid to BWE<br>High                                    | 35<br>60                                           |     | ns    | Max XTAL              |
| t <sub>DSWH</sub>  | Data Valid to BWE<br>High                                    | txTAL+txCH-40<br>txTAL+txCH-60                     |     | ns    | Any XTAL∕<br>%50 XTAL |
| tDHW               | Data Hold from BWE<br>High                                   | 10<br>10                                           |     | ns    | Any XTAL              |
| t <sub>DTSW</sub>  | Data tri-state from BW<br>High                               | Ē                                                  | 50  | ns    | Any XTAL              |
| -                  | in this table only are refer<br>ls except t <sub>DHW</sub> . | enced to                                           |     |       |                       |

TABLE 25. BUFFER RAM WRITE TIMING (EXTERNAL OSCILLATOR)

# 5.3.12 Buffer RAM Read Timing (External Oscillator; XTAL=8 to 20 MHz)



FIGURE 19. BUFFER RAM READ TIMING (EXTERNAL OSCILLATOR)

| SYMBOL              | CHARACTERISTIC              | MIN<br>20 MHz<br>12 MHz                            | UNITS | CONDITIONS        |
|---------------------|-----------------------------|----------------------------------------------------|-------|-------------------|
| tadcy               | Address Cycle Time          | 72<br>125                                          | ns    | Max XTAL/50% XTAL |
| tADCY               | Address Cycle Time          | 2*t <sub>XTAL</sub> -28<br>2*t <sub>XTAL</sub> -35 | ns    | Any XTAL          |
| †BASR               | Address Setup to BOE High   | 72<br>125                                          | ns    | Max XTAL/50% XTAL |
| †BASR               | Address Setup to BOE High   | 2*txtal-28<br>2*txtal-35                           | ns    |                   |
| t <sub>BR</sub>     | BOE Pulse Width             | 45<br>75                                           | ns    | Max XTAL/50% XTAL |
| t <sub>BR</sub>     | BOE Pulse Width             | txtal+txch-30<br>txtal+txch-45                     |       | Any XTAL          |
| t <sub>BAHR</sub>   | Address Hold from BOE High  | 0<br>0                                             | ns    | Any XTAL          |
| tros                | Data Setup to BOE<br>High   | 5<br>5                                             | ns    | Any XTAL          |
| tRDH                | Data Hold from BOE<br>High  | 10<br>10                                           | ns    | Any XTAL          |
| tDHW                | Data Hold from Address      | 10<br>10                                           | ns    |                   |
| All timings levels. | in this table referenced to | 1.5 V                                              |       |                   |

TABLE 26. BUFFER RAM READ TIMING (EXTERNAL OSCILLATOR)

# 5.3.13 Microprocessor Write Timing (INTEL Bus)



FIGURE 20. MICROPROCESSOR WRITE TIMING (INTEL BUS)

| SYMBOL        | CHARACTERISTIC             | MIN       | UNITS | CONDITIONS       |
|---------------|----------------------------|-----------|-------|------------------|
| taval         | Address Setup to ALE Low   | 15        | ns    |                  |
| talai         | Address Hold from ALE Low  | 5         | ns    |                  |
| taleh         | ALE High Pulse Width       | 30        | ns    |                  |
| tadvwh        | Data Setup to MWE High     | 50<br>130 | ns    | HSMB=0<br>HSMB=1 |
| twhDi         | Data Hold from MWE<br>High | 5         | ns    |                  |
| <b>t</b> MWEL | MWE Low Pulse Width        | 75        | ns    |                  |
| tadwl         | Address Valid to MWE Low   | 55        | ns    |                  |
| twhLH         | MWE High to ALE High       | 10        | ns    |                  |

**TABLE 27. MICROPROCESSOR WRITE TIMING (INTEL BUS)** 

# 5.3.14 Microprocessor Write Timing (Motorola Bus)



FIGURE 21. MICROPROCESSOR WRITE TIMING (MOTOROLA BUS)

| SYMBOL            | CHARACTERISTIC                   | MIN       | UNITS | CONDITIONS       |
|-------------------|----------------------------------|-----------|-------|------------------|
| taval             | Address Setup to AS<br>Low       | 15        | ns    |                  |
| <b>t</b> ALAI     | Address Hold from AS             | 5         | ns    |                  |
| tash              | AS High Pulse Width              | 30        | ns    |                  |
| tadvds            | Data Setup to DS Low             | 50<br>130 | ns    | HSMB=0<br>HSMB=1 |
| tosoi             | Data Hold from DS<br>Low         | 5         | ns    |                  |
| tosh              | DS High Pulse Width during Write | 75        | ns    |                  |
| twlDS             | R/W Low to DS High               | 5         | ns    |                  |
| toswh             | DS Low to R/W High               | 20        | ns    |                  |
| tadds             | Address High to DS<br>High       | 55        | ns    |                  |
| t <sub>DSAH</sub> | DS Low to AS High                | 10        | ns    |                  |

TABLE 28. MICROPROCESSOR WRITE TIMING (MOTOROLA BUS)

### 27

### 5.3.15 Microprocessor Read Timing (INTEL Bus)



FIGURE 22. MICROPROCESSOR READ TIMING (INTEL BUS)

| SYMBOL            | CHARACTERISTIC                         | MIN | MAX | UNITS |
|-------------------|----------------------------------------|-----|-----|-------|
| taval             | Address Setup to ALE<br>Low            | 15  |     | ns    |
| talai             | Address Hold from ALE Low              | 5   |     | ns    |
| tALEH             | ALE High Pulse Width                   | 30  |     | ns    |
| taldv             | Data Valid from MRE<br>Low             |     | 100 | ns    |
| t <sub>DHRH</sub> | Data Hold from MRE<br>High             | 10  |     | ns    |
| trhDi             | <u>Data</u> Tri-state from<br>MRE High |     | 50  | ns    |
| tMREL             | MRE Low Pulse Width                    | 100 |     | ns    |
| tadar             | Address Valid to MRE Low               | 55  |     | ns    |
| trhlh             | MRE High to ALE High                   | 10  |     | ns    |

TABLE 29. MICROPROCESSOR READ TIMING (INTEL BUS)

# 5.3.16 Microprocessor Read Timing (Motorola Bus)



FIGURE 23. MICROPROCESSOR READ TIMING (MOTOROLA BUS)

| SYMBOL            | CHARACTERISTIC                  | MIN | MAX | UNITS |
|-------------------|---------------------------------|-----|-----|-------|
| taval             | Address Setup to AS<br>Low      | 15  |     | ns    |
| talai             | Address Hold from AS Low        | 5   |     | ns    |
| tash              | AS High Pulse Width             | 30  |     | ns    |
| tDSDV             | Data Valid from DS<br>High      |     | 100 | ns    |
| t <sub>DSDI</sub> | Data Tri-state from DS<br>Low   |     | 50  | ns    |
| tosh              | DS High pulse Width during Read | 100 |     | ns    |
| tadds             | Address Valid to DS<br>High     | 55  |     | ns    |
| tDSAH             | DS Low to AS High               | 10  |     | ns    |

TABLE 30. MICROPROCESSOR READ TIMING (MOTOROLA BUS)

### 5.3.17 Write Data Timing (MFM/RLL Mode; WC 5 to 15 MHz)



FIGURE 24. WRITE DATA TIMING (MFM/RLL MODE)

| SYMBOL           | 2                      | MIN<br>0 MH<br>2 MH | Z          | UNITS |
|------------------|------------------------|---------------------|------------|-------|
| twc              | WC Pulse Width         | 28<br>45            | 500<br>500 | ns    |
| t <sub>WLE</sub> | Early/Late Propagation | 3<br>3              | 15<br>25   | ns    |
| two              | WD Propagation Delay   | 3<br>3              | 15<br>25   | ns    |
| twcF             | WC Frequency           | 1                   | 15<br>10   | MHz   |

TABLE 31. WRITE DATA TIMING (MFM/RLL MODE)

27

# 5.3.18 Write Data Timing (NRZ Mode; WC 5 to 15 MHz)



FIGURE 25. WRITE DATA TIMING (NRZ MODE)

| SYMBOL | CHARACTERISTIC            | MIN<br>20 MHz<br>12 MHz | MAX                  | UNITS |  |
|--------|---------------------------|-------------------------|----------------------|-------|--|
| twcL   | WC Pulse Width Low        | 20<br>27                | 500<br>500           | ns    |  |
| twch   | WC Pulse Width High       | 20<br>27                | 500<br>500           | ns    |  |
| twlE   | Early/Late Propagation    | 3<br>3                  | 15<br>25             | ns    |  |
| two    | WD Propagation Delay      | 3<br>3                  | 15<br>25             | ns    |  |
| twcF   | WC Frequency              | 1<br>1                  | 22<br>16.5           | MHz   |  |
| twcoL  | WCOUT Pulse Width<br>Low  | twch - 5<br>twch - 9    |                      | ns    |  |
| twcoL  | WCOUT Pulse Width<br>Low  |                         | twc+ 5<br>twc+ + 9   | ns    |  |
| twcoh  | WCOUT Pulse Width<br>High | twcн - 5<br>twcн - 9    |                      | ns    |  |
| twcoH  | WCOUT Pulse Width<br>High |                         | twch + 5<br>twch + 9 | ns    |  |
| twowco | WD Prop Delay from WCOUT  | -5<br>-8                | +5<br>+8             | ns    |  |

TABLE 32. WRITE DATA TIMING (MFM/RLL MODE)

27-83

## 5.3.19 Read Data Timing (MFM/RLL Mode; RC/WC 5 to 15 MHz)



FIGURE 26. READ DATA TIMING (MFM/RLL)

| SYMBOL           |                                     | MIN<br>20 MF<br>12 MH | łz           | UNITS |
|------------------|-------------------------------------|-----------------------|--------------|-------|
| trcp             | RC Pulse Width                      | 27<br>45              | 500<br>500   | ns    |
| t <sub>X1</sub>  | RC Transition to Next<br>Leading RD | 5<br>10               |              | ns    |
| t <sub>X2</sub>  | Leading RD to Next RC<br>Transition | 20<br>20              |              | ns    |
| t <sub>RD</sub>  | Read Data Pulse<br>Width            | 20<br>30              | tRCP<br>tRCP | ns    |
| t <sub>DRN</sub> | DRUN Low Pulse<br>Width             | 25<br>25              |              | ns    |
| trcf             | RC Frequency                        | 1<br>1                | 15<br>10     | MHz   |

TABLE 33. READ DATA TIMING (MFM/RLL)

## 5.3.20 Read Data Timing (NRZ Mode; WC 5 to 20 MHz)



FIGURE 27. READ DATA TIMING (NRZ MODE)

| SYMBOL |                      | MIN<br>20 MH<br>12 MH | lz         | UNITS |
|--------|----------------------|-----------------------|------------|-------|
| tRCP   | RC Pulse Width       | 20<br>27              | 500<br>500 | ns    |
| trns   | RD Setup to RC High  | 7<br>10               |            | ns    |
| tRNH   | RD Hold from RC High | n 7<br>10             |            | ns    |
| trcf   | RC Frequency         | 1<br>1                | 22<br>16.5 | MHz   |

TABLE 34. READ DATA TIMING (NRZ MODE)

### 27

#### 5.3.21 Miscellaneous Timing



FIGURE 28. MISCELLANEOUS TIMING

**%** 

12/4/90

| SYMBOL            | CHARACTERISTIC                               | MIN      | MAX    | UNITS   | CONDITIONS                                            |
|-------------------|----------------------------------------------|----------|--------|---------|-------------------------------------------------------|
| tipx              | Index Pulse Width                            | 100      |        | ns      |                                                       |
| tsct              | SCT Pulse Width                              | 100      |        | ns      |                                                       |
|                   |                                              |          | 4 14/6 |         | Con data 20 in Dill made Ann                          |
| tiwg              | Index to write gate                          | 0        | 4 000  | periods | Gap data=33 in RLL mode. Any gap data in MFM and NRZ. |
| twgwd             | Write gate to write data                     | 0        | 4 WC   | periods |                                                       |
| trsti             | RESET in pulse width low                     | 24       | WC     | periods |                                                       |
| tmrw              | MR Trailing to Host<br>Register Write        | 2.4      |        | μs      |                                                       |
| FRCWC             | Difference of RC Frequency from WC Frequency | -15%     | +15%   |         |                                                       |
| trstl             | RESET Out Low Pulse Width during Power-up    | 51.2     |        | ms      | XTAL=10 MHz                                           |
| trstl             | RESET Out Low Pulse Width during Power-up    | 41.3     |        | ms      | XTAL=12.5 MHz                                         |
| t <sub>RSTL</sub> | RESET Out Low Pulse Width during Power-up    | 25.6     |        | ms      | XTAL=20 MHz                                           |
| TXTAL             | Clock Period                                 | 50<br>70 | 125    | ns      |                                                       |
| tхсн              | Clock High Time                              | 25<br>30 |        | ns      |                                                       |
| txcL              | Clock Low Time                               | 25<br>30 |        | ns      |                                                       |
|                   | NOTE                                         |          |        |         |                                                       |
| txtal, txch, an   | d t <sub>XCL</sub> timings at 2.5 V lev      | els.     |        |         |                                                       |

**TABLE 35. MISCELLANEOUS TIMING** 



#### **NOTES**

- 1. n = contents of sector number register during format command.
- 2. CL = controller latency. 1/2  $\leq$  CL  $\leq$  1-1/2 byte times.
- 3. x = contents of PLO register. ID PLO length is programmable during format command. Data PLO length is programmable during write command. Data PLO length is 11 during format. Data PLO length is 12  $\pm$  1 (or  $x + 13 \pm 1$ ) during write if x = 0 (x > 0).
- 4.  $t_{WGON} = 17 \pm 1$  bit times with respect to RD in.
- 5. twGOFF1 = 28 bit times with respect to WD out.
- 6.  $t_{RGOFF1} = 9 \pm 1$  bit times with respect to RD in.
- 7.  $t_{RGOFF2} = 9 \pm 1$  bit times with respect to RD in.
- 8.  $t_{RGON1} = 19 \pm 1$  bit times with respect to DRUN.
- 9. tRGON2 = 35 + 1 bit times with respect to RD in.

FIGURE 29. SOFT SECTOR MFM/RLL TRACK FORMAT

2 1



#### **NOTES**

- 1. n = contents of sector number register during format command.
- 2. CL = controller latency. 1/2  $\leq$  CL  $\leq$  1-1/2 byte times.
- 3. x = contents of PLO register. ID PLO length is programmable during format command. Data PLO length is programmable during write command. Data PLO length is 11 during format. Data PLO length is 12  $\pm$  1 (or  $x + 13 \pm 1$ ) during write if x = 0 (x > 0).
- 4.  $tw_{GON}$  = 17  $\pm$  1 bit times with respect to NRZRD in.

- 5. twGOFF1 = 28 bit times with respect to NRZWD out.
- 6.  $t_{RGOFF1} = 9 \pm 1$  bit times with respect to NRZRD in.
- 7.  $t_{RGOFF2} = 9 \pm 1$  bit times with respect to NRZRD in.
- 8.  $t_{RGON1} = 3 \pm 1$  bit times with respect to AMF.
- 9.  $t_{RGON2}$  = 35 + 1 bit times with respect to NRZRD in.
- 10.  $t_{WRREC}$  = 21 to 35 bytes minimum.  $t_{RREC}$  = 23 bytes minimum.

FIGURE 30. SOFT SECTOR NRZ TRACK FORMAT

1/2



- 2. CL = controller latency.  $1/2 \le CL \le 1-1/2$  byte times.
- 3. x = contents of PLO register. ID PLO length is programmable during format command. Data PLO length is programmable during write command. Data PLO length is 11 during format. Data PLO length is  $12 \pm 1$  ( $x + 13 \pm 1$ ) during write if x = 0 (x > 0).
- 4.  $t_{WGON} = 17 \pm 1$  bit times with respect to RD in.
- 5. twgoff1 = 28 bit times with respect to WD out.
- 6.  $t_{RGOFF1} = 9 \pm 1$  bit times with respect to RD in.

- 7.  $t_{RGOFF2} = 9 \pm 1$  bit times with respect to RD in. 8.  $t_{RGON1} = 19 \pm 1$  bit times with respect to DRUN. SECTOR is tied to DRUNSCT during format. DRUN is tied to DRUNSCT during read and write.
- 9. t<sub>RGON2</sub> = 35 + 1 bit times with respect to RD in. 10. GAP2 = Speed tolerance + combined ENDEC delays + other gap requirements, e.g. servo.
- GAP2 length = (time between sector pulses) (time from start of GAP1/GAP3 to end of data pad.)

FIGURE 31. HARD SECTOR RLL/MFM TRACK FORMAT (WITH SOFT SECTOR READ/WRITE)

//

12/4/90



- **NOTES**
- 1. n = contents of sector number register during format command.
- 2. CL = controller latency.  $1/2 \le CL \le 1-1/2$  byte
- 3. x = contents of PLO register. ID PLO length is programmable during format command. Data PLO length is programmable during write command. Data PLO length is 11 during format. Data PLO length is  $12 \pm 1$  (x +  $13 \pm 1$ ) during write if x = 0 (x > 0).
- 4.  $t_{WGON} = 17 \pm 1$  bit times with respect to RD in.
- 5. twgoff1 = 28 bit times with respect to WD out.
- 6.  $t_{RGOFF1} = 9 \pm 1$  bit times with respect to RD in.

- 7.  $t_{RGOFF2} = 9 \pm 1$  bit times with respect to RD in.
- 8.  $t_{RGON1} = z + CL$  byte times with respect to INDEX/SECTOR (SCT). SECTOR is tied to DRUNSCT always. z = contents of internal GAP register.
- 9.  $t_{RGON2} = 35 + 1$  bit times with respect to RD in. 10. GAP2 = Speed tolerance + combined ENDEC delays + other gap requirements, e.g. servo.
- GAP2 length = (time between sector pulses) -(time from start of GAP1/GAP3 to end of data pad.)

FIGURE 32. HARD SECTOR RLL/MFM TRACK FORMAT (WITH HARD SECTOR READ/WRITE AND **CONTINUOUS WG OPTION)** 



- 1. n = contents of sector number register during format command.
- 2. CL = controller latency. 1/2  $\leq$  CL  $\leq$  1-1/2 byte times.
- 3. x= contents of PLO register. ID PLO length is programmable during format command. Data PLO length is programmable during write command. Data PLO length is 11 during format. Data PLO length is 12  $\pm$  1 (or  $x+13\pm1$ ) during write if x=0 (x>0).
- 4.  $twGON = 17 \pm 1$  bit times with respect to RD in.
- 5. twGOFF1 = 28 bit times with respect to WD out.
- 6.  $t_{RGOFF1} = 9 \pm 1$  bit times with respect to RD in.
- 7.  $t_{RGOFF2} = 9 \pm 1$  bit times with respect to RD in.

- 8.  $t_{RGON1} = z + CL$  byte times with respect to INDEX/SECTOR (SCT). SECTOR is tied to DRUNSCT always. z = contents of internal GAP register.
- 9. t<sub>RGON2</sub> = 35 + 1 bit times with respect to RD in. 10. GAP2 = Speed tolerance + combined ENDEC delays + other gap requirements, e.g. servo.
- GAP2 length = (time between sector pulses) (time from start of GAP1/GAP3 to end of data pad.)
- 11.  $t_{FWGON} = n + 5 + CL$  byte times with respect to INDEX/SECTOR.  $t_{WGOFF} = 20$  bit times with respect to WD out.

FIGURE 33. HARD SECTOR RLL/MFM TRACK FORMAT (WITH HARD SECTOR READ/WRITE AND WG PULSE)

**//** 

12/4/90



- 1. n = contents of sector number register during format command.
- 2. CL = controller latency.  $1/2 \le CL \le 1-1/2$  byte times.
- 3. x= contents of PLO register. ID PLO length is programmable during format command. Data PLO length is programmable during write command. Data PLO length is 11 during format. Data PLO length is 12  $\pm$  1 (or  $x+13\pm1$ ) during write if x=0.
- 4.  $tw_{GON}$  = 17  $\pm$  1 bit times with respect to NRZRD in.
- 5. twGOFF1 = 28 bit times with respect to NRZWD out.
- 6.  $t_{RGOFF1} = 9 \pm 1$  bit times with respect to NRZRD in.

- 7.  $t_{RGOFF2} = 9 \pm 1$  bit times with respect to NRZRD in.
- 8.  $t_{RGON1} = z + CL$  byte times with respect to INDEX/SECTOR (SCT). z = contents of internal GAP register.
- 9.  $t_{RGON2} = 35 + 1$  bit times with respect to NRZRD in.
- 10. tw<sub>GLOW</sub> = 2 bit times. tw<sub>GOFF2</sub> = 8 bit times. Both timings with respect to NRZWD out.
- 11. GAP2 = Speed tolerance + combined ENDEC delays + other gap requirements, e.g. servo.
- GAP2 length = (time between sector pulses) (time from start of GAP1/GAP3 to end of data pad.)

FIGURE 34. HARD SECTOR NRZ TRACK FORMAT

### 6.0 PACKAGE DIAGRAMS



FIGURE 35. 84-PIN PLCC PACKAGE DIMENSIONS

//

12/4/90



FIGURE 36. 84-PIN PQFP PACKAGE DIMENSIONS